百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

使用树莓派+DHT22做一个温湿度计

itomcoil 2025-02-13 12:30 9 浏览

先上一些照片。

硬件:树莓派+DHT22温湿度传感器(白色的那个就是)。

网页,显示当前时间、最新一条监测记录。

传感器记录写入DB程序。

一个简单的查询数据程序。

整个程序下来,涉及了:

树莓派、DHT22温湿度传感器、Python3、SQLite3、Nginx、JQuery。


缘起:

因为疫情原因,在家的时间比较长,一直是在书房工作学习。偶尔去趟客厅,现在天热,客厅朝南,又没开空调,就比较闷热潮湿。我就比较想知道客厅的温湿度。

家里倒是有个物理温湿度计,就是这玩意儿:


不过作为一个IT男,数据不数码化,总觉得很不爽,所以就动了心思买个电子温度计,家里小米的多,就想买这个:

但是现在穷的叮当响,又恰好翻箱底的时候,翻出了我的老树莓派——确实很老了,是很多年前,刚出来的时候买的,GPIO引脚还是26针的,配套的SD卡也找着了,因为这款没有WIFI,恰好又有富余的网线,一装系统还能运行,所以干脆就自己搞吧。


过程:不能放外链,大家想用就搜搜吧。

1、安装系统:

1.1 格式化SD卡:去SD官方网站下载专门的格式化工具


1.2 安装树莓派系统:

下载烧录程序

下载系统

分别是:桌面+命令行版、桌面版、命令行版。我选的是第一个,回头可以在配置里将启动改为进入命令行界面。

烧录:

这个没啥了,选系统镜像,选SD卡,写入。


1.2 系统配置:

升级:

sudo apt-get update
sudo apt-get dist-upgrade

通过桌面首选项,可以打开VNC、SSH服务。

VNC是桌面连接,我们在电脑上用VNC Viewer可以访问树莓派桌面。

SSH是远程命令行访问,在终端上使用命令"ssh pi@树莓派IP"即可。

安装Python3.

安装Nginx、安装SQLite。

安装ufw防火墙,打开端口:

sudo ufw allow 80#Nginx端口
sudo ufw allow 8080#Python的HTTP服务接口
sudo ufw allow 22#SSH端口
sudo ufw allow 5900#VNC端口

2、硬件安装:

去某宝买了DHT22温湿度传感器+杜邦线,20块钱,从汕头发过来的。

传感器一共有三个针脚“+、-、out”

我的树莓派比较老旧,只有26个针脚:


如图,+接入3.3v,-接入Ground,out接入GPIO2。

正负极可不能接反了,会烧的。


3、程序:

3.1 创建数据库、表:

#!/usr/bin/python
import sqlite3
conn=sqlite3.connect('temper.db')
print("Open temperDB")
c = conn.cursor()
c.execute('''CREATE TABLE temper
       (ID INTEGER PRIMARY KEY   autoincrement,
       create_time DEFAULT (datetime('now', 'localtime')),
       temp            CHAR(50)     NOT NULL,
       humi        CHAR(50) NOT NULL);''')
print('Table created successfully')
conn.commit()
conn.close()

3.2 下载读取传感器相关驱动:

sudo apt-get install build-essential python-dev
git clone https://github.com/adafruit/Adafruit_Python_DHT.git
cd Adafruit_Python_DHT
sudo python3 setup.py install

3.3 每隔10分钟,读取传感器记录写入到数据库

#!/usr/bin/python
import Adafruit_DHT
from datetime import datetime
import time
import sqlite3
sensor = Adafruit_DHT.DHT22
#pin = 'P8_11'
pin = 2
def timer(n):
    while True:
        humidity, temperature = Adafruit_DHT.read_retry(sensor, pin)
        if humidity is not None and temperature is not None:
            print(datetime.now().strftime("%Y-%m-%d %H:%M:%S"))
            print('温度={0:0.1f}*C  湿度={1:0.1f}%'.format(temperature, humidity))
            conn = sqlite3.connect('temper.db')
            c = conn.cursor()
            c.execute("INSERT INTO temper (temp,humi) VALUES ("+'{0:0.1f}'.format(temperature)+","+'{0:0.1f}'.format(humidity)+")")
            conn.commit()
            conn.close()
        else:
            print('Failed to get reading. Try again!')
        time.sleep(n)
timer(600)

3.4 Python服务端,返回JSON格式的最新记录:

#!/usr/bin/python
from http.server import HTTPServer, BaseHTTPRequestHandler
import json
import sqlite3
host = ('0.0.0.0', 8080)#开8080端口
class Resquest(BaseHTTPRequestHandler):
    def do_GET(self):
        self.send_response(200)
        self.send_header('Content-type', 'application/json')
        self.send_header('Accexx-Control-Allow-Origin','*')#解决跨域问题
        self.end_headers()
        conn = sqlite3.connect('temper.db')
        c = conn.cursor()
        cursor = c.execute("SELECT *  from temper order by id desc limit 0,1")
        for row in cursor:
            data = {'id':row[0],'time':row[1],'temp':row[2],'humi':row[3]}
        result="returnTemp("+json.dumps(data)+")"
        self.wfile.write(result.encode())
if __name__ == '__main__':
    server = HTTPServer(host, Resquest)
    print("Starting server, listen at: %s:%s" % host)
    server.serve_forever()

3.5 网页

编辑
/var/www/html/index.nginx-debian.html





 
温湿度计






4、启动:

分别启动Nginx、dht.py、serv.py

访问网页http://192.168.31.88



5、一些问题:

因为我毕竟是搞Java服务端开发的,用Python也只是处理一下数据,页面跨域的问题在实际工作中,运维人员就解决了,所以搞这一块有点手生,不过也是很快解决了。

本来我想让开机自启动的,但是查了不少资料,做了不少测试,总是有问题,所以暂时也不弄,就这么跑者吧。


6、后续的一些规划:

因为数据都入库了,我准备使用ECharts,将历史数据做一个折线图。

另外某宝上也看了墨水屏,可以接到树莓派上,将网页上的信息展示在上面。不过那玩意儿也太贵了,4.2寸的要快200了,舍不得啊。

相关推荐

MySql安装与使用

介绍mysql是目前最流行的关系型数据库管理系统,在WEB应用方面MySQL是最好的RDBMS(RelationalDatabaseManagementSystem:关系数据库管理系统)应用软件...

使用AI来搭建一个用户系统,步骤应该是怎样的呢?

我给AI的第一个问题是这样的:创建一个java21+springboot3.4+mysql21的一个用户系统,需要使用JWT,支持多语言,使用swagger,这个用户系统都应该包含哪...

Mysql 8.4数据库安装、新建用户和数据库、表单

1、下载MySQL数据库yuminstall-ywgetperlnet-toolslibtirpc#安装wget和perl、net-tools、libtirpcwgethtt...

介绍如何在 MySQL 中创建新用户并授予权限?

MySQL是一个开源的关系型数据库管理系统,常用于存储和管理大量的结构化数据。在使用MySQL进行数据管理时,为了安全和方便管理,通常需要创建新用户并授予相应的权限。本文将介绍如何在MySQL...

Mysql创建用户和权限管理

MySQL是一个多用户的数据库,最高权限管理者是root用户,它拥有着最高的权限操作。包括select、update、delete、update、grant等操作。如果有其他用户想使用MySQL,那么...

Mysql:创建用户详解

1、创建并授权用户--创建可从任何主机连接的用户CREATEUSER'myuser'@'%'IDENTIFIEDBY'mypassword'...

Python 实现【字符匹配】

defis_match(s,pattern):m,n=len(s),len(pattern)dp=[[False]*(n+1)for_inrange...

Python自动化:openpyxl工作簿、工作表相关操作

新建工作簿、工作表importopenpyxl#创建空白工作簿,会自动生成一个工作表:Sheetwb=openpyxl.Workbook()#新建工作表#create_sheet...

python每日一练之三数排序

概述今天主要分享一个三树排序的实例,大家可以自己测试玩一下~需求输入三个整数x,y,z,请把这三个数由小到大输出。方法一:如果是要练练手就随便找个排序算法实现一下#usr/bin/python#...

Python输出语句print()

Python中的输出语句主要通过内置函数print()实现,它可以灵活输出文本、变量、表达式结果等内容到控制台或其他文件。以下是详细介绍及示例:一、print()基本语法print(*object...

Python设置excel表格格式,这3个属性6个模块,要表格好看

前言:通过前面两篇文章,我们用Python处理excel数据得到了结果并保存了文件。打开文件会发现,文件里表格是没有设置格式的,还需手动调整行高列宽等样式,很麻烦。其实,通过Python库模块,能轻松...

python入门-day5-循环语句

以下是为“Day5:循环语句”设计的详细学习任务计划。这个任务旨在帮助初学者掌握Python中的循环语句(for和while),并通过实践理解它们的应用场景。Day5:循环语句学习目标...

Python基础编程必备!涵盖常见语法与操作的代码示例合集

以下是一份Python基础代码示例合集,涵盖了常见的语法和操作,适合初学者快速掌握基本编程概念:1.基础语法python#打印输出print("Hello,World!")#变...

Python循环语句实用教程

一、循环基础1.while循环基本语法:while条件表达式:循环体代码while循环流程图:应用示例:#简单计数器count=0whilecount<5:...

在 Python 中如何向一个已排序的数组(列表) 中插入一个数呢

在Python中如何向一个已排序的数组(列表)中插入一个数呢?方法有很多种,关键在于原来数组是什么样的排序,用到啥排序方法效率高,就用哪种。我们来练习其中的几种插入方法,另外也掌握下遍历数组的...