python如何异步执行同步调用?
q = queue.Queue()
def run()
while True:
url = q.get()
res = requests.get(url)
# 此处把结果返回
t1 = threading.Thread(target=run)
t1.start()
t2...
t3...
def req(url):
q.put(url)
# 此处等待执行完毕获取返回结果并return
# 正常调用
res = req(url)
简单来说就是把url放在一个队列里,由队列去发送请求,方便统一控制频率
在使用的时候和正常使用requests库一样,能满足这样的需求就可以
望各位不吝赐教啊
--
上一个问题:python 爬虫如何使用请求队列?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
另一种方法是用
multiprocessing.pool.ThreadPool
,这个接口和multiprocessing.Pool
一样,但是用的是threading
:协程
生产者消费者模式
https://github.com/ray-projec...