Using Raspberry PI with DHT11 Temperature and Humidity Sensor and Python

Check my RPI articles in Best Raspberry PI projects article or peppe8o.com home page. Or subscribe my newsletter (top right in this page) to be notified when new projects are available! Also interested to start 3D printing with a cheap budget? Visit my cheap 3D printers list
5
(2)

This article shows you how to interface a Raspberri PI with DHT11 Sensor using Python.

DHT11 sensor

DHT11 Sensor is a cheap solution to measure indoor Temperature and Humidity (it is not indicated for outdoor uses). It can be used with Arduino (usually in Weather Station projects or similar) or alone, directly connected to a Raspberry PI.

For this article, I’m going to use a Raspberry PI Zero W with soldered header. But this article apply also to other Raspberry PI boards.

What We Need

As usual, I suggest adding from now to your favourite ecommerce shopping chart all needed hardware, so that at the end you will be able to evaluate overall costs and decide if continuing with the project or removing them from shopping chart. So, hardware will be only:

Raspberry PI Zero WH board
Raspberry PI Zero WH board

You can also use newer Raspberry PI boards instead of Raspberry PI Zero W. You may also find useful evaluating a sensors kit (like Elegoo Starter Kit) which is a cost saving solution if you want to test many sensors for different purposes.

Check hardware prices with following links:

Amazon raspberry pi boards box
Amazon raspberry pi Zero W box
Amazon Micro SD box
Amazon Raspberry PI Power Supply box
Amazon DHT11 umidity temperature box

Step-by-Step Procedure

Wiring Diagram

Please refer to following picture for wiring:

RPI DHT11 wiring

Note that DHT11 signal (Data) pin is connected to RPI pin 11, which corresponds to GPIO 17 (refer to Raspberry PI GPIO schemas for complete schema).

Install OS (Raspberry PI OS Lite)

Start preparing your Operating System. You can install the fast Raspberry PI OS Lite (without Desktop environment) or you can also opt for Raspberry PI OS Desktop, using its internal terminal.

Make sure your OS is up to date with following commands:

sudo apt update
sudo apt upgrade

Istall CircuitPython Libraries

CircuitPython libraries are a set of Python libraries from Adafruit which simplify external sensors management. These libraries require Python3. Check if it is installed with command:

python3 --version

Otherwise, install python3:

sudo apt install python3

Install pip for python3:

sudo apt install python3-pip

Enable I2C and SPI

Enable and configure I2C (standard designed to allow one chip to talk another)

sudo apt install -y python-smbus
sudo apt install -y i2c-tools

And enable Raspberry PI I2C kernel support with:

sudo raspi-config

In following config screen, go to Interfacing Options > I2C. Enable it by pressing yes in next screen and following confirmation. Once enabled, you should be forwarded again to raspi-config home page.

To enable SPI, go again in Interfacing Options >SPI. Enable it by pressing yes in next screen and following confirmation.

Click Finish in raspi-config home page to go back ssh terminal.

Install Python Libraries

Start from GPIO library:

pip3 install RPI.GPIO

Finally, install adafruit-blinka library. This includes also a few different libraries such as adafruit-pureio (our ioctl-only i2c library), spidev (for SPI interfacing), Adafruit-GPIO (for detecting your board) and of course adafruit-blinka):

pip3 install adafruit-blinka

Setup CircuitPython-DHT

Following adafruit dht library will be required to enable communication of Raspberry PI with DHT11 sensor:

pip3 install adafruit-circuitpython-dht
sudo apt install libgpiod2

Create a new reading script named DHT11Test.py:

nano DHT11Test.py

Insert the following code:

import time
import board
import adafruit_dht
#Initial the dht device, with data pin connected to:
dhtDevice = adafruit_dht.DHT11(board.D17)
while True:
     try:
         # Print the values to the serial port
         temperature_c = dhtDevice.temperature
         temperature_f = temperature_c * (9 / 5) + 32
         humidity = dhtDevice.humidity
         print("Temp: {:.1f} F / {:.1f} C    Humidity: {}% "
               .format(temperature_f, temperature_c, humidity))
    except RuntimeError as error:     # Errors happen fairly often, DHT's are hard to read, just keep going
         print(error.args[0])
    time.sleep(2.0)

And finally execute by typing:

 python3 DHT11Test.py

This code will show measured data and also makes you aware that DHT11 sensor naturally receives a number of reading errors (as also referenced in adafruit comment inside the script):

pi@raspberrypi:~ $ python3 DHT11Test.py
Temp: 66.2 F / 19.0 C    Humidity: 56%
Temp: 66.2 F / 19.0 C    Humidity: 56%
Temp: 66.2 F / 19.0 C    Humidity: 56%
Temp: 66.2 F / 19.0 C    Humidity: 56%
Checksum did not validate. Try again.
Temp: 66.2 F / 19.0 C    Humidity: 56%
A full buffer was not returned.  Try again.
Temp: 66.2 F / 19.0 C    Humidity: 56%
Checksum did not validate. Try again.
Temp: 66.2 F / 19.0 C    Humidity: 56%
Temp: 66.2 F / 19.0 C    Humidity: 56%
Temp: 66.2 F / 19.0 C    Humidity: 56%
Temp: 66.2 F / 19.0 C    Humidity: 56%
Temp: 66.2 F / 19.0 C    Humidity: 56%

To have a clean list of correct measurements, change inside code the line “print(error.args[0])” with “pass”. This avoids printing errors on terminal and outputs readings when it is corretly received:

pi@raspberrypi:~ $ python3 DHT11Test.py
Temp: 66.2 F / 19.0 C    Humidity: 55%
Temp: 66.2 F / 19.0 C    Humidity: 55%
Temp: 66.2 F / 19.0 C    Humidity: 55%
Temp: 66.2 F / 19.0 C    Humidity: 55%
Temp: 66.2 F / 19.0 C    Humidity: 55%
Temp: 66.2 F / 19.0 C    Humidity: 55%
Temp: 66.2 F / 19.0 C    Humidity: 55%
Temp: 66.2 F / 19.0 C    Humidity: 55%

Enjoy!

How useful was this post?

Click on a star to rate it anonymously!

Average rating 5 / 5. Vote count: 2

No votes so far! Be the first to rate this post.

We are sorry that this post was not useful for you!

Let us improve this post!

Tell us how we can improve this post?