之前的文章大部分都使用了urllib2,但是树莓派pip3已不支持urllib2.所以本次使用了urllib。
见代码
onenet部分:
"""
@author:wgc
@Time:2019/5/10 15:19
@Version: v1.0
"""
import urllib.request
import json
import time
import dht12
from time import sleep
#设备ID
deviceId = "659717893"
APIKey = "wxEuUVHPxHBL0DPdy865vC=jvDI="
def get_temp():
# 打开文件
# 读取结果,并转换为浮点数
temp = dht12.dht111()
# 关闭文件
print(temp)
# 向控制台打印结果
print("CPU tempurature: %.3f" %temp )
# 返回温度值
return temp
#上传函数
def http_put_data(data):
temperature=get_temp()
url = "http://api.heclouds.com/devices/" + deviceId + '/datapoints'
d = time.strftime('%Y-%m-%dT%H:%M:%S')
values = {"datastreams": [ {"id": "CO2", "datapoints": [{"value": temperature}]}, {"id": "PM25", "datapoints": [{"value": temperature}]},
{"id": "PM10", "datapoints": [{"value": temperature}]},{"id": "VOC", "datapoints": [{"value": temperature}]} ]}
jdata = json.dumps(values).encode("utf-8")
request = urllib.request.Request(url, jdata)
request.add_header('api-key', APIKey)
request.get_method = lambda: 'POST'
request = urllib.request.urlopen(request)
return request.read()
if __name__ == '__main__':
R = http_put_data(10)
print(R)
dht11部分代码
import RPi.GPIO as GPIO
import time
def delayMicrosecond(t): # 微秒级延时函数
start,end=0,0 # 声明变量
start=time.time() # 记录开始时间
t=(t-3)/1000000 # 将输入t的单位转换为秒,-3是时间补偿
while end-start<t: # 循环至时间差值大于或等于设定值时
end=time.time() # 记录结束时间
tmp=[] # 用来存放读取到的数据
data = 18 # DHT11的data引脚连接到的树莓派的GPIO引脚,使用BCM编号
a,b=0,0
def DHT11():
GPIO.setup(data, GPIO.OUT) # 设置GPIO口为输出模式
GPIO.output(data,GPIO.HIGH) # 设置GPIO输出高电平
delayMicrosecond(10*1000) # 延时10毫秒
GPIO.output(data,GPIO.LOW) # 设置GPIO输出低电平
delayMicrosecond(25*1000) # 延时25毫秒
GPIO.output(data,GPIO.HIGH) # 设置GPIO输出高电平
GPIO.setup(data, GPIO.IN) # 设置GPIO口为输入模式
a=time.time() # 记录循环开始时间
while GPIO.input(data): # 一直循环至输入为低电平
b=time.time() # 记录结束时间
if (b-a)>0.1: # 判断循环时间是否超过0.1秒,避免程序进入死循环卡死
break # 跳出循环
a=time.time()
while GPIO.input(data)==0: # 一直循环至输入为高电平
b=time.time()
if (b-a)>0.1:
break
a=time.time()
while GPIO.input(data): # 一直循环至输入为低电平
b=time.time()
if (b-a)>=0.1:
break
for i in range(40): # 循环40次,接收温湿度数据
a=time.time()
while GPIO.input(data)==0: #一直循环至输入为高电平
b=time.time()
if (b-a)>0.1:
break
delayMicrosecond(28) # 延时28微秒
if GPIO.input(data): # 超过28微秒后判断是否还处于高电平
tmp.append(1) # 记录接收到的bit为1
a=time.time()
while GPIO.input(data): # 一直循环至输入为低电平
b=time.time()
if (b-a)>0.1:
break
else:
tmp.append(0) # 记录接收到的bit为0
def dht111():
GPIO.setmode(GPIO.BCM) # 设置为BCM编号模式
GPIO.setwarnings(False)
del tmp[0:] # 删除列表
time.sleep(1) # 延时1秒
DHT11()
humidity_bit=tmp[0:8] # 分隔列表,第0到7位是湿度整数数据
humidity_point_bit=tmp[8:16]# 湿度小数
temperature_bit=tmp[16:24] # 温度整数
temperature_point_bit=tmp[24:32] # 温度小数
check_bit=tmp[32:40] # 校验数据
humidity_int=0
humidity_point=0
temperature_int=0
temperature_point=0
check=0
for i in range(8): # 二进制转换为十进制
humidity_int+=humidity_bit[i]*2**(7-i)
humidity_point+=humidity_point_bit[i]*2**(7-i)
temperature_int+=temperature_bit[i]*2**(7-i)
temperature_point+=temperature_point_bit[i]*2**(7-i)
check+=check_bit[i]*2**(7-i)
humidity=humidity_int+humidity_point/10
temperature=temperature_int+temperature_point/10
check_tmp=humidity_int+humidity_point+temperature_int+temperature_point
if check==check_tmp and temperature!=0 and temperature!=0: # 判断数据是否正常
print("Temperature is ", temperature,"C\nHumidity is ",humidity,"%")# 打印温湿度数据
print("https://blog.zeruns.tech")
return temperature
else:
print("error")
time.sleep(1)
GPIO.cleanup()