【发布时间】:2020-05-01 04:52:52
【问题描述】:
我目前正在尝试在树莓派上运行一个小脚本来调查我的功耗。
每次我的计数器执行脉冲(紧密接触)并计算“即时”功耗时,此脚本通常会中断。
问题是,当我从 IDE (Thonny) 运行该脚本时,它可以完美运行,但我不能直接在命令行中运行它(python 或 python3,sudo 与否,最后是 &...)。我的目标是将其作为吸引人的“python3 myscript.py”服务运行。当我运行它时,我没有收到任何消息、错误或任何东西。它似乎停止了。 这是我的脚本
#!/usr/bin/env python3
import mysql.connector as mariadb
import datetime
import time
import RPi.GPIO as GPIO
mariadb_connection = mariadb.connect(user='Elec', password='****', database='Elec')
cursor = mariadb_connection.cursor()
cursor.execute("SELECT datetime FROM Compteur ORDER BY nb DESC LIMIT 1")
gett = cursor.fetchone()
last = gett[0]
GPIO.setmode(GPIO.BCM)
GPIO.setup(17, GPIO.IN, pull_up_down=GPIO.PUD_UP)
def impulse(channel):
global last
now = datetime.datetime.now()
delta = datetime.timedelta.total_seconds(now-last)
last = datetime.datetime.now()
Pinst = round(3.6/delta ,3)
heure = int(now.strftime("%H"))
if heure > 20 or heure < 7:
HPHC = 'HC'
else:
HPHC = 'HP'
cursor.execute("INSERT INTO Compteur (Puiss,datetime,HPHC) VALUES (%s,%s,%s)",
(Pinst,now.strftime("%Y-%m-%d %H:%M:%S"), HPHC))
mariadb_connection.commit()
GPIO.add_event_detect(17, GPIO.FALLING, callback=impulse, bouncetime=500)
我的想法已经不多了,如果您有什么要尝试的,请...提前致谢!
【问题讨论】:
-
你试过白痴调试了吗? (即,在每个主要步骤之后放置
print语句,以便您可以看到它停止的位置)。 -
或者学习 Python 的内置调试器,它总是在命令行上可用。
-
您是否尝试过在通话结束时省略“&”。 & 将在后台启动脚本,并且不会将任何输出打印到终端。
-
实际上我找到了一种“棘手”的方法来让它发挥作用。我在最后添加了一段时间 True 以保持脚本处于活动状态。有谁知道让脚本执行等待中断的任何其他方法?无论如何感谢您的 cmets
标签: python