树莓派Flask+DTH11传感器做Web界面显示

小白一枚 刚刚接触编程 树莓派和python 打算开启代码之旅。做了个小玩意打算记录下来。大佬们勿喷。

DTH11传感器实现参照别人的,这里主要学了一点Flask框架知识,将DTH11得到的数值传送给模板html文件中的变量{{}}(占位符)实现web端的显示。
web界面
![嘿嘿 最最最简单的界面 html/css/js知识目前未学习多少
实物图
DTH11.py

import RPi.GPIO as GPIO
import time
#temperature = 0
def fun(temperature):
    channel = 4         #引脚号4
    data = []           #温湿度值
    j = 0               #计数器
     
    GPIO.setmode(GPIO.BCM)      #以BCM编码格式

    time.sleep(1)           #时延一秒
     
    GPIO.setup(channel, GPIO.OUT)
     
    GPIO.output(channel, GPIO.LOW)
    time.sleep(0.02)        #给信号提示传感器开始工作
    GPIO.output(channel, GPIO.HIGH)
     
    GPIO.setup(channel, GPIO.IN)
     
    while GPIO.input(channel) == GPIO.LOW:
        continue
     
    while GPIO.input(channel) == GPIO.HIGH:
        continue
     
    while j < 40:
        k = 0
        while GPIO.input(channel) == GPIO.LOW:
            continue
        
        while GPIO.input(channel) == GPIO.HIGH:
            k += 1
            if k > 100:
                break
        
        if k < 8:
            data.append(0)
        else:
            data.append(1)
     
        j += 1
     
    print("sensor is working.")
    print(data)             #输出初始数据高低电平
     
    humidity_bit = data[0:8]        #分组
    humidity_point_bit = data[8:16]
    temperature_bit = data[16:24]
    temperature_point_bit = data[24:32]
    check_bit = data[32:40]
     
    humidity = 0
    humidity_point = 0
    #global temperature
    #temperature=0
    temperature_point = 0
    check = 0
     
    for i in range(8):
        humidity += humidity_bit[i] * 2 ** (7 - i)              #转换成十进制数据
        humidity_point += humidity_point_bit[i] * 2 ** (7 - i)
        temperature += temperature_bit[i] * 2 ** (7 - i)
        temperature_point += temperature_point_bit[i] * 2 ** (7 - i)
        check += check_bit[i] * 2 ** (7 - i)
     
    tmp = humidity + humidity_point + temperature + temperature_point       #十进制的数据相加
     
    if check == tmp:                                #数据校验,相等则输出
        print ("temperature 温度: ", temperature, ", humidity 湿度: " , humidity)
    else:                                       #错误输出错误信息,和校验数据
        print ("wrong")
        print ("temperature 温度: ", temperature, ", humidity 湿度: " , humidity, " check : ", check, " tmp : ", tmp)
    GPIO.cleanup()
    return  temperature,humidity
    

同级目录下模板templates内的DTHweb.html文件
两行而已

        <h1>DTH11测量温度和湿度</h1>
        <p>温度:{{i}}     湿度:{{j}}</p>

DTH11_run.py

import DTH11
from flask import Flask, render_template , request
import RPi.GPIO as GPIO

app = Flask(__name__)
@app.route('/',methods=['GET','POST'])
def index():
    temp = 0
    list_result=[]
    #列表
    result=DTH11.fun(temp)
    print(result[0])
    print(type(result[0]))
    print(result[1])

    return render_template('DTHweb.html',i = str(result[0])+str(u'\u2103'),j= str(result[1])+'%')
if __name__=='__main__':
    app.run(host='0.0.0.0', port=8866, debug=True)

文件目录如下
在这里插入图片描述
//download.csdn.net/download/weixin_44557559/12188572

  • 4
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
如果你想在 Flask 中添加界面显示,可以使用 Flask 自带的模板引擎 Jinja2。Jinja2 允许你使用 HTML 模板来渲染动态内容,从而生成用户界面。 首先,你需要在 Flask 应用程序中配置模板目录。在你的 Flask 应用程序中添加以下代码: ```python from flask import Flask, render_template app = Flask(__name__) app.template_folder = '/path/to/templates' ``` 在上面的代码中,`/path/to/templates` 是包含 HTML 模板的目录的路径。 现在,你可以在 Flask 应用程序中使用 `render_template` 函数来渲染 HTML 模板。这个函数接受一个模板名称和一些关键字参数,这些关键字参数将在模板中用于渲染动态内容。例如: ```python from flask import Flask, render_template app = Flask(__name__) app.template_folder = '/path/to/templates' @app.route('/') def index(): name = 'John' return render_template('index.html', name=name) ``` 在上面的代码中,`index` 函数将渲染 `index.html` 模板,并将 `name` 变量传递给模板。在模板中,你可以使用 Jinja2 语法来访问这些变量,例如: ```html <!DOCTYPE html> <html> <head> <title>Hello {{ name }}</title> </head> <body> <h1>Hello {{ name }}</h1> </body> </html> ``` 在上面的代码中,`{{ name }}` 将在模板中被替换为 `John`。 当你访问 Flask 应用程序的根路径时,`index` 函数将被调用,`index.html` 模板将被渲染,并将生成一个包含 `Hello John` 的页面。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值