Более или менее знак в Python появляется, когда этот код выполняется - PullRequest
0 голосов
/ 09 января 2019

Я пытаюсь вставить данные Python в таблицу MySQL. Я использую датчик температуры DS18B20. Я пробовал много учебников, но я не могу понять, как добавить MySQL в код Python, используемый для получения данных о температуре. Любая помощь будет оценена! Теперь я обновил свой код, и ошибка отступа исчезла. Но когда я выполняю этот код, ничего не происходит, и знак «больше или меньше», чем python (>>>), является единственным, что генерируется при выполнении моего кода.

Вот этот питон:

import os
import glob
import time
import MySQLdb
import datetime

i = datetime.datetime.now()

db = MySQLdb.connect(host = "localhost", 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)
          time = 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() 

1 Ответ

0 голосов
/ 09 января 2019
import os
import glob
import time
import MySQLdb
import datetime

i = datetime.datetime.noW()

db = MySQLdb.connect(host = "localhost", 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)
          timestring = hour + ":" + minute + ":" + second

          try:
             cur.execute("""INSERT INTO TAB_CLASSROOM(temp_c,rec_time,rec_date) VALUES(%s,%s,%s)""",(valT,timestring,date))
             db.commit()
          except:
             db.rollback()

          time.sleep(10)

cur.close()
db.close()

согласно моему редактору, ваше утверждение WHILE не имеет правильного отступа. В зависимости от версии pythonm, 2.7 или 3.X, вы можете, если это будет 3.x, нуждаться () в операторе print через некоторое время.

...