当前位置: 首页 > article >正文

树莓派实战指南:从零搭建DHT11温湿度监测系统

1. 认识你的硬件伙伴DHT11与树莓派第一次拿到DHT11温湿度传感器时我盯着这个比指甲盖还小的模块看了半天——就这么个小东西能测量环境数据后来实测发现它虽然精度不如实验室设备但家用完全够用。DHT11通过单总线协议通信这意味着只需要一根数据线就能传输数据特别适合树莓派这种GPIO接口有限的设备。传感器背面标注着三个引脚VCC3.3-5V供电、DATA数据线、GND接地。这里有个新手容易踩的坑DATA引脚需要接上拉电阻4.7KΩ-10KΩ不过现在市面上大多数DHT11模块已经内置电阻买回来直接就能用。我对比过DHT11和DHT22的区别前者测量范围是20-90%RH湿度和0-50℃温度精度±5%后者虽然精度更高±2%RH±0.5℃但价格贵三倍对于室内监测来说DHT11性价比更高。树莓派这边以4B型号为例我们需要关注GPIO引脚排列。有个记忆技巧将板子以太网接口朝右左上角第一个引脚是1号3.3V电源右边是2号5V电源向下依次排列。推荐使用GPIO4物理引脚7号因为这个引脚在多数教程中都被用作示例后续软件配置会更方便。2. 硬件连接从物理搭建到信号测试实际接线时我建议用颜色区分的杜邦线红色接VCC1号引脚黑色接GND9号引脚黄色接DATA7号引脚。接好后通电能看到DHT11模块上的LED闪烁这是正常现象。如果使用面包板过渡注意接触不良是导致读取失败的主要原因之一——我有次调试两小时才发现是杜邦线金属头氧化了。测试硬件是否正常有个小技巧用万用表测量VCC和GND之间电压应该是3.3V然后测量DATA引脚电压。正常状态下DATA应该是高电平约3.3V当树莓派发送起始信号时会拉低电平。如果没有万用表可以用这个土方法手指轻触传感器表面观察湿度值是否有变化人体会影响局部温湿度。遇到过最头疼的问题是电源干扰。有次我把传感器接在5V引脚上虽然DHT11标称支持5V供电但和树莓派3.3V的GPIO通信时出现了电平不匹配。后来改用3.3V供电就稳定了。如果遇到数据不稳定可以尝试缩短连接线长度最好小于20cm在VCC和GND之间加装0.1μF去耦电容避免将传感器放置在强电磁干扰源附近3. 三种数据读取方案实战对比3.1 系统Device Tree方案在/boot/config.txt添加dtoverlaydht11,gpiopin4是最简单的方法重启后会在/sys/devices生成设备节点。实测发现这个方案读取成功率约70%因为单总线协议对时序要求严格。改进方法是写个Shell脚本循环读取#!/bin/bash DHT11_PATH/sys/devices/platform/dht114/iio:device0 for i in {1..5}; do humidity$(cat $DHT11_PATH/in_humidityrelative_input) temperature$(cat $DHT11_PATH/in_temp_input) if [ $humidity -gt 0 ] [ $temperature -gt 0 ]; then echo 湿度:$(awk BEGIN{print $humidity/1000})% echo 温度:$(awk BEGIN{print $temperature/1000})℃ break fi sleep 1 done优点是系统级集成适合与其他服务配合缺点是采样间隔不能小于2秒DHT11的物理限制。3.2 Python方案Adafruit库优化版原版Adafruit库在树莓派4B上需要手动修改platform_detect.py我整理了个改进版安装流程pip3 install adafruit-circuitpython-dht sudo apt-get install libgpiod2示例代码增加了异常重试机制import adafruit_dht import board import time dht adafruit_dht.DHT11(board.D4) for _ in range(3): try: temp dht.temperature humidity dht.humidity if temp is not None and humidity is not None: print(f温度: {temp}℃ 湿度: {humidity}%) break except RuntimeError: time.sleep(2)这个方案成功率提升到90%但要注意必须用sudo运行GPIO访问权限每次读取间隔建议≥2秒长时间运行可能出现内存泄漏需要定期重启脚本3.3 C语言方案带信号滤波针对工业级应用我用C重写了驱动加入数字滤波#include wiringPi.h #include stdio.h #include stdlib.h #define MAX_TIMINGS 85 #define DHT_PIN 4 int data[5] {0}; void read_dht() { uint8_t laststate HIGH, counter 0; for (int i0; i5; i) data[i] 0; pinMode(DHT_PIN, OUTPUT); digitalWrite(DHT_PIN, LOW); delay(18); digitalWrite(DHT_PIN, HIGH); delayMicroseconds(40); pinMode(DHT_PIN, INPUT); for (int i0; iMAX_TIMINGS; i) { counter 0; while (digitalRead(DHT_PIN) laststate) { counter; delayMicroseconds(1); if (counter 255) break; } laststate digitalRead(DHT_PIN); if (counter 255) break; if ((i 4) (i%2 0)) { data[(i-4)/2] 1; if (counter 16) data[(i-4)/2] | 1; } } if ((data[4] ((data[0] data[1] data[2] data[3]) 0xFF)) (data[0] ! 0 || data[2] ! 0)) { printf(湿度: %d.%d%% 温度: %d.%d℃\n, data[0], data[1], data[2], data[3]); } } int main() { wiringPiSetup(); while(1) { read_dht(); delay(2000); } return 0; }编译时加-O2优化级别能提高时序精度gcc -O2 -o dht11 dht11.c -lwiringPi4. 数据持久化与可视化实战4.1 SQLite数据库存储我习惯用SQLite存储历史数据先创建数据库sqlite3 environmental.db CREATE TABLE readings( id INTEGER PRIMARY KEY AUTOINCREMENT, timestamp DATETIME DEFAULT CURRENT_TIMESTAMP, temp REAL, humidity REAL )Python插入数据的完整示例import sqlite3 from datetime import datetime def log_reading(temp, humidity): conn sqlite3.connect(/home/pi/environmental.db) c conn.cursor() c.execute(INSERT INTO readings (temp, humidity) VALUES (?,?), (temp, humidity)) conn.commit() conn.close()4.2 实时可视化方案用FlaskChart.js搭建的轻量级Web界面是我的首选。服务端代码from flask import Flask, render_template import sqlite3 app Flask(__name__) app.route(/) def dashboard(): conn sqlite3.connect(environmental.db) c conn.cursor() c.execute(SELECT timestamp, temp, humidity FROM readings ORDER BY timestamp DESC LIMIT 100) data c.fetchall() conn.close() return render_template(dashboard.html, datadata) if __name__ __main__: app.run(host0.0.0.0, port8080)前端页面关键代码dashboard.htmlcanvas idchart width800 height400/canvas script srchttps://cdn.jsdelivr.net/npm/chart.js/script script const ctx document.getElementById(chart).getContext(2d); new Chart(ctx, { type: line, data: { labels: [{% for row in data %}{{ row[0] }}{% if not loop.last %},{% endif %}{% endfor %}], datasets: [ { label: 温度(℃), data: [{% for row in data %}{{ row[1] }}{% if not loop.last %},{% endif %}{% endfor %}], borderColor: red }, { label: 湿度(%), data: [{% for row in data %}{{ row[2] }}{% if not loop.last %},{% endif %}{% endfor %}], borderColor: blue } ] } }); /script4.3 异常报警功能通过SMTP发送邮件报警的Python实现import smtplib from email.mime.text import MIMEText def send_alert(temp, humidity): msg MIMEText(f异常环境数据当前温度: {temp}℃, 湿度: {humidity}%) msg[Subject] 环境监测警报 msg[From] raspberrypiexample.com msg[To] your_emailexample.com with smtplib.SMTP(smtp.example.com, 587) as server: server.starttls() server.login(username, password) server.send_message(msg)在读取数据后加入判断逻辑if temp 30 or humidity 80: send_alert(temp, humidity)对于没有固定IP的情况可以用Telegram Bot实现报警import requests TELEGRAM_TOKEN your_bot_token CHAT_ID your_chat_id def telegram_alert(message): url fhttps://api.telegram.org/bot{TELEGRAM_TOKEN}/sendMessage params {chat_id: CHAT_ID, text: message} requests.post(url, paramsparams)

相关文章:

树莓派实战指南:从零搭建DHT11温湿度监测系统

1. 认识你的硬件伙伴:DHT11与树莓派 第一次拿到DHT11温湿度传感器时,我盯着这个比指甲盖还小的模块看了半天——就这么个小东西能测量环境数据?后来实测发现它虽然精度不如实验室设备,但家用完全够用。DHT11通过单总线协议通信&am…...

CAN总线分析仪实战:从安装配置到数据收发调试全解析

1. CAN总线分析仪入门指南 第一次接触CAN总线分析仪的朋友可能会觉得这东西有点神秘,其实它就是个帮我们和汽车电子设备"对话"的翻译官。我刚开始用的时候也是一头雾水,后来发现只要掌握几个关键步骤,就能轻松上手。现在市面上常见…...

CAN总线测试与示波器选型实战指南

1. CAN总线测试基础与示波器选型在汽车电子和工业控制领域,CAN总线测试是每个工程师必须掌握的硬核技能。我从事车载诊断系统开发八年,实测过上百个CAN节点,深刻体会到正确使用示波器进行信号测试的重要性。与常见的逻辑分析仪不同&#xff0…...

ESP8266对接GLPi的轻量级IoT工单库

1. 项目概述 glpi_esp8266 是一款专为 ESP8266 系列 Wi-Fi 微控制器设计的轻量级 C 库,其核心使命是构建物联网终端设备与企业级 IT 服务管理(ITSM)平台 GLPi 之间的标准化通信桥梁。该库并非直接对接 GLPi 的 REST API,而是通过…...

无网环境部署:OpenClaw离线安装Qwen3-14B镜像指南

无网环境部署:OpenClaw离线安装Qwen3-14B镜像指南 1. 为什么需要离线部署方案 在金融、政务等对数据安全要求极高的领域,服务器通常运行在严格的Air-gap环境(物理隔离网络)中。去年我在某金融机构做POC时,就遇到了这…...

网站SEO优化如何提高网站权重

网站SEO优化如何提高网站权重 在当今数字化时代,网站SEO优化已经成为提升网站权重的关键因素。无论是小型企业还是大型企业,都在为提升网站在搜索引擎结果页面上的排名而努力。如何通过SEO优化来提高网站权重呢?本文将从问题分析、原因说明、…...

MQ2_LPG气体检测库:嵌入式LPG泄漏监测与动态校准实践

1. MQ2_LPG气体检测库深度解析:面向嵌入式系统的LPG泄漏监测工程实践 1.1 库定位与工程价值 MQ2_LPG是一个专为嵌入式平台设计的轻量级气体传感驱动库,核心目标是实现对液化石油气(Liquefied Petroleum Gas, LPG)中丙烷&#xff…...

OpenClaw多模态开发:Qwen2.5-VL-7B实现自动化图文内容审核

OpenClaw多模态开发:Qwen2.5-VL-7B实现自动化图文内容审核 1. 为什么需要本地化内容审核 去年我接手了一个社区运营项目,每天需要审核数百张用户上传的图片和文字内容。最初尝试用第三方审核API,但很快遇到三个痛点:一是敏感数据…...

AI 伦理与可解释AI

**AI伦理与可解释AI:技术发展的双刃剑** 人工智能(AI)的快速发展正在深刻改变社会,但随之而来的伦理问题与“黑箱”难题也引发广泛讨论。AI伦理关注技术应用的道德边界,而可解释AI(XAI)则致力于…...

C++ STL 内存管理策略

C STL内存管理策略解析 C标准模板库(STL)以其高效性和灵活性成为开发者不可或缺的工具,而内存管理策略是其核心优势之一。STL通过智能分配器、容器内部机制及算法优化,实现了内存的高效利用与动态扩展。本文将深入探讨STL的内存管…...

Go测试框架与基准测试

Go测试框架与基准测试:高效代码质量的守护者 在软件开发中,测试是确保代码质量的关键环节。Go语言凭借其简洁高效的特性,内置了强大的测试工具链,包括单元测试框架和基准测试功能。无论是验证逻辑正确性,还是评估性能…...

OpenClaw长期运行方案:Phi-3-mini-128k-instruct服务的稳定性保障

OpenClaw长期运行方案:Phi-3-mini-128k-instruct服务的稳定性保障 1. 为什么需要长期运行方案? 去年冬天的一个深夜,我被手机警报惊醒——部署在家庭服务器的OpenClaw服务崩溃了。当时正在运行的自动化周报生成任务因此中断,导致…...

Go gRPC 流通信机制详解

Go gRPC 流通信机制详解 在现代分布式系统中,高效的数据传输是核心需求之一。gRPC作为Google开源的高性能RPC框架,凭借其基于HTTP/2的流式通信能力,成为微服务通信的热门选择。Go语言因其简洁性和高并发特性,与gRPC结合尤为紧密。…...

Python高频面试题:python里面模块和包之间有什么区别?

大家好,我是锋哥。今天分享关于【Python高频面试题:python里面模块和包之间有什么区别?】面试题 。希望对大家有帮助; Python高频面试题:python里面模块和包之间有什么区别? 在 Python 里,**模…...

Java高频面试题:Netty的内存池机制怎样设计的?

大家好,我是锋哥。今天分享关于【Java高频面试题:Netty的内存池机制怎样设计的?】面试题 。希望对大家有帮助;Java高频面试题:Netty的内存池机制怎样设计的?Netty 的内存池机制是一个非常核心且复杂的部分,它的设计主…...

网络SEO的主要指标有哪些

网络SEO的主要指标有哪些 前言 在当今数字化时代,网络SEO(搜索引擎优化)是每一个网站拥有高流量和高曝光度的关键。SEO是一个复杂而又充满挑战的领域,涉及许多技术和策略。究竟有哪些是网络SEO的主要指标呢?本文将详…...

Go netpoll 实现机制分析

Go netpoll 实现机制分析 在现代高并发网络编程中,高效的事件驱动机制是提升性能的关键。Go语言通过其独特的netpoll模块,实现了轻量级且高效的I/O多路复用,支撑了Go标准库中net包的强大能力。本文将深入分析Go netpoll的实现机制&#xff0…...

5个贝叶斯概率实战案例:从医学诊断到垃圾邮件过滤(附Python代码)

5个贝叶斯概率实战案例:从医学诊断到垃圾邮件过滤(附Python代码) 贝叶斯概率不仅是统计学中的经典理论,更是解决现实问题的利器。想象一下:医生如何通过检测结果判断患者真实患病概率?邮箱如何智能识别垃圾…...

5个实战案例解析:如何用VLA模型让机器人听懂人话并执行任务(附开源项目推荐)

5个实战案例解析:如何用VLA模型让机器人听懂人话并执行任务(附开源项目推荐) 当机器人能像人类助手一样理解"把茶几上的遥控器拿过来"这样的日常指令时,具身智能才真正开始改变我们的生活。视觉-语言-动作(V…...

Playwright同步与异步模式全对比:从基础使用到多线程实战避坑

Playwright同步与异步模式全对比:从基础使用到多线程实战避坑 在自动化测试和网页爬虫领域,Playwright凭借其跨浏览器支持和现代化API设计迅速成为开发者新宠。但对于Python开发者而言,面对同步和异步两种编程模式的选择,常常陷入…...

虚拟列表原理与实现,并在 Vue 项目场景中怎么实现

这是前端面试里的中高频题,尤其是你简历里如果写了:长列表优化大数据量渲染性能优化表格优化Vue 项目优化那几乎很容易被问到。这道题如果只回答:“虚拟列表就是只渲染可视区域的数据。”这个回答方向没错,但太浅。 如果你能讲到&…...

OpenClaw技能扩展:Qwen3.5-9B支持的内容创作自动化实践

OpenClaw技能扩展:Qwen3.5-9B支持的内容创作自动化实践 1. 为什么选择OpenClawQwen3.5-9B组合 去年冬天,当我第一次尝试用AI自动化处理每周的技术博客草稿时,最头疼的就是如何在本地环境实现稳定的内容生成与发布流程。经过多次尝试&#x…...

【LaTeX】入门和使用拾遗

文章目录0 前言1 基本概述1.1 代码框架1.2 环境配置2 常用指令2.1 中文支持2.2 字号及其单位2.3 插图2.4 插入参考文献2.5 设置跳转链接2.6 双栏显示2.7 常用输入0 前言 记得最早接触LaTeX还是在大二参加数学建模大赛的时候,当时比较懵懂,对工具非常“迷…...

WinAsar实战指南:高效处理Electron asar文件的专业工具

WinAsar实战指南:高效处理Electron asar文件的专业工具 【免费下载链接】WinAsar Portable and lightweight GUI utility to pack and extract asar( Electron archive ) files, Only 551 KB! 项目地址: https://gitcode.com/gh_mirrors/wi/WinAsar WinAsar是…...

GPT-SoVITS V3 API实战:用Python几行代码实现流式语音合成与格式转换

GPT-SoVITS V3 API实战:用Python几行代码实现流式语音合成与格式转换 语音合成技术正在经历一场革命性的变革。从早期机械感十足的TTS系统,到如今能够模仿人类情感起伏的AI语音,技术的进步让合成语音越来越自然。GPT-SoVITS V3作为这一领域的…...

NCM解密工具全解析:突破加密壁垒实现音频自由

NCM解密工具全解析:突破加密壁垒实现音频自由 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 问题剖析:加密格式如何成为数字资产的枷锁? 在数字音乐时代,我们常常面临一个矛盾&#…...

离线语音识别新选择:Whisper Web本地部署与内网穿透实战指南

1. 为什么选择Whisper Web进行本地语音识别 在当今AI技术快速发展的时代,语音识别已经成为我们日常工作和生活中不可或缺的工具。但大多数语音识别服务都需要依赖云端,这不仅带来了隐私泄露的风险,还受限于网络连接质量。Whisper Web的出现完…...

MAX31865驱动PT100温度测量全栈指南

1. MAX31865高精度PT100 RTD温度传感器接口芯片深度解析 MAX31865是Maxim Integrated(现属Analog Devices)推出的专用RTD(Resistance Temperature Detector,热电阻)数字转换器,专为工业级铂电阻温度测量而设…...

如何利用 Google Analytics 来优化网站 SEO

如何利用 Google Analytics 来优化网站 SEO 在当今数字营销中,SEO(搜索引擎优化)无疑是每个网站主的首要任务之一。而在SEO优化的过程中,Google Analytics 作为一款强大的分析工具,能够为网站主提供宝贵的数据和洞察&…...

OpenClaw成本优化:Qwen3.5-9B长任务拆解与Token消耗监控

OpenClaw成本优化:Qwen3.5-9B长任务拆解与Token消耗监控 1. 为什么需要关注OpenClaw的Token消耗 上周我让OpenClaw帮我整理一个季度的工作报告,结果第二天发现账户里的大模型调用额度几乎见底。查看日志才发现,这个看似简单的任务竟然消耗了…...