我有一个python代码,我正在开发一个网站,除其他外,创建一个Excel工作表,然后将其转换为一个json文件。我需要这个代码连续运行,除非它被网站管理员杀死。
为此,我正在使用APscheduler。
代码在没有APscheduler的情况下运行完美,但是当我尝试添加其余代码时,会发生以下两种情况之一; 1)尽管使用" ctrl + C"它仍会永远运行并且不会停止我需要使用任务管理器停止它或2)它只运行一次,然后停止
不停止的代码:
from apscheduler.scheduler import Scheduler
import logging
import time
logging.basicConfig()
sched = Scheduler()
sched.start()
(...)
code to make excel sheet and json file
(...)
@sched.interval_schedule(seconds = 15)
def job():
excelapi_final()
while True:
time.sleep(10)
sched.shutdown(wait=False)
一次后停止运行的代码:
from apscheduler.scheduler import Scheduler
import logging
import time
logging.basicConfig()
sched = Scheduler()
(...)
#create excel sheet and json file
(...)
@sched.interval_schedule(seconds = 15)
def job():
excelapi_final()
sched.start()
while True:
time.sleep(10)
sched.shutdown(wait=False)
我从其他问题中了解到,sched.shutdown
应该允许ctrl + C杀死代码的一些教程和文档 - 但这不起作用。有任何想法吗?提前谢谢!
答案 0 :(得分:2)
您可以使用独立模式:
sched = Scheduler(standalone=True)
然后像这样启动调度程序:
try:
sched.start()
except (KeyboardInterrupt):
logger.debug('Got SIGTERM! Terminating...')
您更正后的代码应如下所示:
from apscheduler.scheduler import Scheduler
import logging
import time
logging.basicConfig()
sched = Scheduler(standalone=True)
(...)
code to make excel sheet and json file
(...)
@sched.interval_schedule(seconds = 15)
def job():
excelapi_final()
try:
sched.start()
except (KeyboardInterrupt):
logger.debug('Got SIGTERM! Terminating...')
这样,当按下 Ctrl-C 时程序将停止
答案 1 :(得分:0)
您可以正常关闭它:
import signal
from apscheduler.scheduler import Scheduler
import logging
import time
logging.basicConfig()
sched = Scheduler()
(...)
#create excel sheet and json file
(...)
@sched.interval_schedule(seconds = 15)
def job():
excelapi_final()
sched.start()
def gracefully_exit(signum, frame):
print('Stopping...')
sched.shutdown()
signal.signal(signal.SIGINT, gracefully_exit)
signal.signal(signal.SIGTERM, gracefully_exit)