基于树莓派的数据采集与存储.docx

上传人:b****2 文档编号:2933700 上传时间:2023-05-05 格式:DOCX 页数:14 大小:378.21KB
下载 相关 举报
基于树莓派的数据采集与存储.docx_第1页
第1页 / 共14页
基于树莓派的数据采集与存储.docx_第2页
第2页 / 共14页
基于树莓派的数据采集与存储.docx_第3页
第3页 / 共14页
基于树莓派的数据采集与存储.docx_第4页
第4页 / 共14页
基于树莓派的数据采集与存储.docx_第5页
第5页 / 共14页
基于树莓派的数据采集与存储.docx_第6页
第6页 / 共14页
基于树莓派的数据采集与存储.docx_第7页
第7页 / 共14页
基于树莓派的数据采集与存储.docx_第8页
第8页 / 共14页
基于树莓派的数据采集与存储.docx_第9页
第9页 / 共14页
基于树莓派的数据采集与存储.docx_第10页
第10页 / 共14页
基于树莓派的数据采集与存储.docx_第11页
第11页 / 共14页
基于树莓派的数据采集与存储.docx_第12页
第12页 / 共14页
基于树莓派的数据采集与存储.docx_第13页
第13页 / 共14页
基于树莓派的数据采集与存储.docx_第14页
第14页 / 共14页
亲,该文档总共14页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

基于树莓派的数据采集与存储.docx

《基于树莓派的数据采集与存储.docx》由会员分享,可在线阅读,更多相关《基于树莓派的数据采集与存储.docx(14页珍藏版)》请在冰点文库上搜索。

基于树莓派的数据采集与存储.docx

基于树莓派的数据采集与存储

《嵌入式综合实践》

设计报告

 

一、树莓派简介

RaspberryPi(中文名为“树莓派”,简写为RPi,或者RasPi/RPi)是为学生计算机编程教育而设计,只有信用卡大小的卡片式电脑,其系统基于Linux。

随着Windows10IoT的发布,我们也将可以用上运行Windows的树莓派。

自问世以来,受众多计算机发烧友和创客的追捧,曾经一“派”难求。

别看其外表“娇小”,内“心”却很强大,视频、音频等功能通通皆有,可谓是“麻雀虽小,五脏俱全”。

二、配置树莓派

1.树莓派供电

树莓派的供电装置与智能手机的充电器是一样的。

基本规格为DC5V(直流电),至少达到700mA的输出电流,树莓派2的输出电流应该更大,比如1.5A或2A。

2.手动对SD存储卡进行写操作(windows)

选择一张4GB以上的SD存储卡,SD卡插入笔记本电脑卡槽(或者需要一个读卡器)。

下载官方发行的树莓派操作系统发行包(),并解压到本地。

用管理员权限打开FedoraARMInstaller(下载),将下载的镜像写入SD存储卡。

如下图:

 

3.连接笔记本电脑显示器

✧网络设置:

SD卡插入树莓派的SD卡插槽,把树莓派和路由器用网线连接。

打开电脑“网络和共享中心”,点击“WLAN(***)”点击“属性”,点击“共享”,在“允许其他网络用户通过此计算机的Internet来连接”前打勾。

 

✧查找树莓派IP地址:

打开“运行”(win+R键),输入cmd”,输入“arp-a”,在下图中的0x4接口下的动态地址就为树莓派的IP地址。

✧下载PuTTy,在HostName中输入树莓派IP,

✧登入树莓派:

在下图页面中login处输入树莓派账号(pi),在password处输入密码(raspberry)。

回车

进入下图页面

✧树莓派的桌面环境配置:

在上putty中输入sudoapt-getupdate;sudoapt-getinstalltightvncserver。

安装完成vnc服务后,在上图中继续输入以下命令:

vncserver:

1(一定要创建连接端口)。

在第一次运行时,会提示你创建密码。

在连接时就需要此密码。

下载RealVNC(),在下图中输入树莓派IP:

1(如192.168.0.113:

1。

在下图中输入上面创建的密码

 

进入树莓派桌面

 

 

三、硬件电路连接

DHT11与树莓派引脚图如下:

 

具体电路连接如下DHT11的VDD连接树莓派17号管脚,GND连接20号管脚,DATA连接18号管脚。

实物图如下:

四、DHT11简介

数字温湿度传感器是一款含有已校准数字信号输出的温湿度复合传感器。

它应用专用的数字模块采集技术和温湿度传感技术,确保产品具有极高的可靠性与卓越的长期稳定性。

DATA用于微处理器与DHT11之间的通讯和同步,采用单总线数据格式,一次通讯时间4ms左右,数据分小数部分和整数部分,具体格式在下面说明,当前小数部分用于以后扩展,现读出为零.操作流程如下:

一次完整的数据传输为40bit,高位先出。

数据格式:

8bit湿度整数数据+8bit湿度小数数据+8bi温度整数数据+8bit温度小数数据+8bit校验和数据传送正确时校验和数据等于“8bit湿度整数数据+8bit湿度小数数据+8bi温度整数数据+8bit温度小数数据”所得结果的末8位。

DHT11发送响应信号,送出40bit的数据,并触发一次信号采集,用户可选择读取部分数据.从模式下,DHT11接收到开始信号触发一次温湿度采集,如果没有接收到主机发送开始信号,DHT11不会主动进行温湿度采集.采集数据后转换到低速模式。

通讯过程如图所示

五、获取DHT11传感器温湿度

采用Python语言实现温湿度的获取,每执行一次程序读取一次温湿度的值。

采用putty中的nano编辑器完成汇编。

步骤如下:

✧登入树莓派,获取root权限

✧进入nano编辑器,编辑Python程序,程序如下:

#!

/usr/bin/envpython

importRPi.GPIOasGPIO

importtimechannel=12

data=[]

j=0

GPIO.setmode(GPIO.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)

whileGPIO.input(channel)==GPIO.LOW:

continue

whileGPIO.input(channel)==GPIO.HIGH:

continue

whilej<40:

k=0

whileGPIO.input(channel)==GPIO.LOW:

continue

whileGPIO.input(channel)==GPIO.HIGH:

k+=1

ifk>100:

break

ifk<8:

data.append(0)

else:

data.append

(1)

j+=1

print"sensorisworking."

printdata

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

temperature=0

temperature_point=0

check=0

foriinrange(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

ifcheck==tmp:

print"temperature:

",temperature,",humidity:

",humidity

else:

print"wrong"

print"temperature:

",temperature,",humidity:

",humidity,"check:

",check,"tmp:

",tmp

GPIO.cleanup()

✧保存(Ctrl+O)并退出(Ctrl+X)

✧执行此程序(dht11.py):

pythondht11.py

六、安装本地MYSQL

✧使用管理员权限运行apt-get获取最新的MySQL及Python编程接口(之后用于数据库编程):

sudoapt-getinstallmysql-serverpython-mysqldb

安装过程中需要输入root管理员的密码,该密码之后用于访问数据库系统。

在本地MYSQL创建库“test”,表“dht”和三个列“dht_tem”,“dht_hum”,“dht_time”。

mysql-uroot–p;登入本地MySQL

createdatabasetest;创建数据库”test”

USEtest;选择数据库”test”

createtabledht;创建表“dht”

CREATETABLEdht(dht_temDECIMAL(4,1),dht_humDECIMAL(4,1),dht_timechar(25));创建列“dht_tem”,“dht_hum”,“dht_time”

完成后查看建好的表“dht”,如下图所示:

✧在之前的dht11.py中添加如下几段语句:

importMySQLdb

conn=MySQLdb.connect(host='localhost',

port=3306,

user='root',

passwd='QAZQAZ',

db='test')

cur=conn.cursor()

value=[temperature,humidity,str(time.strftime('%A%X%Z',time.localtime(time.time())))]

cur.execute("insertintodht(dht_tem,dht_hum,dht_time)values(%s,%s,%s)",value)

mit()

conn.rollback()

✧执行dht11.py:

pythondht11.py

按照之前数据库的操作方法,可在本地数据库MySQL查看到新插入的温湿度数据。

如下图所示(已执行多次程序):

七、连接阿里云RDS数据库

云服务器和云数据库RDS:

云服务上安装了下mysql,在云盾里开放3306端口,远程同样能够正常连接数据库,但云服务器里搭建数据库可能不如云数据库来的稳定,云数据库更易维护。

利用实名账户在阿里云试用一个月的免费云数据库。

具体操作如下:

✧申请阿里云试用一个月的免费云数据库

✧登入阿里云RDS,创建账号”dht_zzx”和创建数据库”dht”

✧登入自己创建的数据库“dht”,创建表“dht11”和三个列“dht_tem”,“dht_hum”,“dht_time”。

结果如下:

✧设置白名单:

0.0.0.0/0即不设置访问限制;

连接信息改为切换外网模式,并将外网地址保存好。

✧在dht11.py中添加如下程序:

importrequests

importjson

db=MySQLdb.connect(host='',

port=3306,

user='dht_zzx',

passwd='qaz123',

db='dht')

cur_db=db.cursor()

cur_db.execute("insertintotb_dht(dht_tem,dht_hum,dht_time)values(%s,%s,%s)",value)

mit()

运行程序,打开阿里云数据库,观察结果,如下:

八、上传数据到传感云

✧申请传感云账号

✧添加一个设备“dht11温湿度采集”,添加两传感器“dht11温度”,“dht11湿度”,得到传感器ID分别为:

565274cce4b0932584ded623,5652756ee4b0932584ded624;

✧在个人中心查看自己的密钥:

c0b419675b8955d2866e224e448b06e1;在API文档的插入数值型传感器数据点查看URL:

在dht11.py中添加如下程序:

#wendu

apiurl=''

apiheaders={'ak':

'c0b419675b8955d2866e224e448b06e1','id':

‘565274cce4b0932584ded623',

’value’:

‘temperature’}

r=requests.post(apiurl,params=apiheaders)

Print(r.text)

#shidu

apiurl=''

apiheaders={'ak':

'c0b419675b8955d2866e224e448b06e1','id':

‘5652756ee4b0932584ded624',

’value’:

‘humidity’}

r=requests.post(apiurl,params=apiheaders)

Print(r.text)

运行程序,打开阿里云数据库,观察结果,如下:

九、Cron实现定时功能

Putty下运行如下程序:

Sudo  crontab –e

*/1****/home/pi/zzx/dht.py;每分钟后台运行dht11.py一次。

 

 

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 初中教育 > 语文

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2