每天在Python中指定的时间后执行常规任务

时间:2015-08-10 14:07:05

标签: python multithreading python-2.7 parsing time

我需要运行一些代码来存储我在日间23:30工作日收集的值列表。为此,我使用了那段代码:

 def sayac_yaz():

    threading.Timer(3600, sayac_yaz).start()

    save_time = datetime.datetime.now()
    if (save_time.hour<23):
        return 

    print "Sayaclari kaydediyor"

    if mem.sayac_okuma_flag==0:
        save_dict=mem.readings_from_counters

    # Connecting to the database file
    conn2 = sqlite3.connect('tenantdata.sqlite')
    c2 = conn2.cursor()

    for idx in save_dict:
        sayac_value=save_dict[idx]
        actual_counter_id=idx
        if isinstance(sayac_value, float):
            # insert a new row with the current date and time, e.g., 2014-03-06
            c2.execute('''INSERT INTO tenant_counter VALUES(?,?,?,?,?)''' , (actual_counter_id, save_time.strftime('%Y-%m-%d'), save_time.strftime('%H:%M:%S'), save_time.strftime('%Y-%m-%d %H:%M:%S'), sayac_value))
        else:
            # insert a new row with the current date and time, e.g., 2014-03-06
            c2.execute('''INSERT INTO tenant_counter VALUES(?,?,?,?,?)''' , (actual_counter_id, save_time.strftime('%Y-%m-%d'), save_time.strftime('%H:%M:%S'), save_time.strftime('%Y-%m-%d %H:%M:%S'), 'Error!'))
    conn2.commit()
    conn2.close()
    return

据我所知,这里我只能在线程启动后每小时运行一次代码。我怎样才能改变它以便它能在每天23:30之后起作用?对我来说尤其是这一部分是重要的。

1 个答案:

答案 0 :(得分:2)

我的建议是使用系统调度程序(Linux上的crontab),因为它是为此目的而设计的。

如果crontab无法触及,您必须保持脚本运行,并定期检查当前时间:

while True:
    now = datetime.datetime.now()
    # call the function between 23:30 and 23:35
    if now.hour == 23 and 30 <= now.minute <35:
       sayac_yaz()
    time.sleep(5*60)