gpt4 book ai didi

python - 在无限循环中停止 python 脚本

转载 作者:太空宇宙 更新时间:2023-11-03 14:30:26 25 4
gpt4 key购买 nike

我正在编写一个 Python 脚本,它会不断地抓取数据,但这需要相当长的时间。有没有一种安全的方法来停止长时间运行的 python 脚本?该循环将运行 10 分钟以上,如果我愿意,我需要一种方法在它已经运行后停止它。

如果我从 cron 作业中执行它,那么我假设它会一直运行到完成,那么我该如何停止它呢?

此外,如果我从浏览器运行它并调用文件。我假设停止加载页面会停止它,对吗?


场景如下:
我有一个 python 脚本,它从页面收集信息并将其放入队列中。然后我想要另一个处于无限循环中的 python 脚本,它只检查队列中的新项目。假设我希望无限循环从早上 8 点开始,到晚上 8 点结束。我该如何实现?

最佳答案

让我给你一个替代方案。您似乎想要实时更新某种信息。您可以使用发布/订阅界面(发布/订阅)。由于您使用的是 Python,因此有很多可能性。

其中一个正在使用 Redis发布/订阅功能:http://redis.io/topics/pubsub/ - 这是相应的 python 模块:redis-py

-更新-

例子

这是来自 dirkk0 的示例( question/answer ):

import sys
import threading

import cmd


def monitor():
r = redis.Redis(YOURHOST, YOURPORT, YOURPASSWORD, db=0)

channel = sys.argv[1]
p = r.pubsub()

p.subscribe(channel)

print 'monitoring channel', channel
for m in p.listen():
print m['data']


class my_cmd(cmd.Cmd):
"""Simple command processor example."""

def do_start(self, line):
my_thread.start()

def do_EOF(self, line):
return True

if __name__ == '__main__':
if len(sys.argv) == 1:
print "missing argument! please provide the channel name."
else:
my_thread = threading.Thread(target=monitor)
my_thread.setDaemon(True)

my_cmd().cmdloop()

-更新2-

另外,看看这个教程:

http://blog.abourget.net/2011/3/31/new-and-hot-part-6-redis-publish-and-subscribe/

关于python - 在无限循环中停止 python 脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11898451/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com