【发布时间】:2019-01-09 01:46:52
【问题描述】:
一旦我运行这个包含一些 mysql 的 python 代码,我得到的只是三个更大或更小的符号(>>>)。任何帮助将非常感激! 我的代码包括尝试通过连接到我的树莓派 3 的 ds18b20 获取温度,并将该数据发送到我创建的 mysql 数据库中。
这里是 python/mysql 代码:
import os
import glob
import time
import MySQLdb
import datetime
i = datetime.datetime.now()
db = MySQLdb.connect(host = "127.0.0.1", user = "root", passwd = "test", db = "temp_pi")
cur = db.cursor()
os.system('modprobe w1-gpio')
os.system('modprobe w1-therm')
base_dir = '/sys/bus/w1/devices/'
device_folder = glob.glob(base_dir + '28*')[0]
device_file = device_folder + '/w1_slave'
def read_temp_raw():
f = open(device_file, 'r')
lines = f.readlines()
f.close()
return lines
def read_temp():
lines = read_temp_raw()
while lines[0].strip()[-3:] != 'YES':
time.sleep(0.2)
lines = read_temp_raw()
equals_pos = lines[1].find('t=')
if equals_pos != -1:
temp_string = lines[1][equals_pos+2:]
temp_c = float(temp_string) / 1000.0
temp_f = temp_c * 9.0 / 5.0 + 32.0
return temp_c
while True:
print ("recording data into database(period = 5s.)....press ctrl+Z to stop!")
valT = str(read_temp())
year = str(i.year)
month = str(i.month)
day = str(i.day)
date = day + "-" + month + "-" + year
hour = str(i.hour)
minute = str(i.minute)
second = str(i.second)
timestr = hour + ":" + minute + ":" + second
try:
cur.execute("""INSERT INTO TAB_CLASSROOM(temp_c,T_Date,T_Time) VALUES(%s,%s,%s)""",(valT,date,time))
db.commit()
except:
db.rollback()
time.sleep(10)
cur.close()
db.close()
【问题讨论】:
-
当你从命令行像这样
python something.py运行它时? -
这是相当长的代码,您希望人们阅读。您应该 a) 包含有关如何运行代码的更多信息,包括您的操作系统,并且 b) 尽可能减少仍然存在问题的代码。
-
@aws_apprentice 当我在 python 模块中运行它时。
-
"@aws_apprentice 当我在 python 模块中运行它时。" - 请更具体一点,这是什么意思? Python 是一个可执行程序。它恰好在模块中运行代码。
-
@mdurant 好吧,我很抱歉。我的代码连接到 mysql db(第 9-10 行),通过我在描述中指定的传感器(12-35)读取温度,然后将它们发送到表(51-55)并最后关闭连接。
标签: python mysql phpmyadmin mysql-python