无法在命令行中运行python脚本

2024-10-03 00:28:57 发布

您现在位置:Python中文网/ 问答频道 /正文

我目前正在尝试在raspberry pi上运行一个小脚本,以便调查我的功耗

通常,每当我的计数器产生脉冲(闭合接触)并计算“瞬时”功耗时,该脚本就会中断

问题是,当我从IDE(Thonny)运行这个脚本时,它可以完美地工作,但我不能直接在命令行中运行它(python或python3、sudo或not,以及最后的…)。我的目标是将其作为一个服务运行,即“python3myscript.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)

我没主意了,所以如果你有什么要尝试的请。。。提前谢谢


Tags: import脚本datetimegpioasconnectioncursornow
1条回答
网友
1楼 · 发布于 2024-10-03 00:28:57

所以我的脚本现在运行了一些时间。我修改它是为了用继电器控制电费开关。这可能会引起某些人的兴趣,他们知道:)

#!/usr/bin/env python3
import mysql.connector as mariadb
import datetime
import time
import RPi.GPIO as GPIO

mariadb_connection = mariadb.connect(user='', password='', 
database='')
cursor = mariadb_connection.cursor()
print ('connected')
cursor.execute("SELECT datetime FROM Compteur ORDER BY nb DESC LIMIT 1")
gett = cursor.fetchone()
last = gett[0]
print (last)
GPIO.setmode(GPIO.BCM)
GPIO.setup(17, GPIO.IN, pull_up_down=GPIO.PUD_UP)
GPIO.setup(18, GPIO.OUT)
HPHC = ''

def impulse(channel):
    global last
    global HPHC
    now = datetime.datetime.now()
    #print (now)
    delta = datetime.timedelta.total_seconds(now-last)
    #print (delta)
    last = datetime.datetime.now()
    Pinst = round(7.2/delta ,3)
    #print (Pinst)
    heure = int(now.strftime("%H"))
    minute = int(now.strftime("%M"))
    #print(heure,minute)
    if heure == 20 and minute >= 56 :
        HPHC = 'HC'
    elif heure > 20:
        HPHC = 'HC'
    elif heure == 4 and minute <= 56 :
        HPHC = 'HC'
    elif heure < 4:
        HPHC = 'HC'
    else :
        HPHC = 'HP'
    #print (HPHC)
    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()
    return HPHC

GPIO.add_event_detect(17, GPIO.FALLING, callback=impulse, bouncetime=500)
print ('boucle')

while True:
    GPIO.setmode(GPIO.BCM)
    time.sleep(0.1)
    if HPHC is 'HC' :
        GPIO.output(18, GPIO.HIGH)
    elif HPHC is 'HP' :
        GPIO.output(18, GPIO.LOW)

相关问题 更多 >