python如何异步执行同步调用?

发布于 2022-09-02 00:16:31 字数 530 浏览 18 评论 0

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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

转瞬即逝 2022-09-09 00:16:31
def req(url):
    resq = queue.Queue()
    q.put((url, resq))
    res = resq.get()
    # ...
def run():
    while True:
        url, resq = q.get()
        res = requests.get(url)
        resq.put(res)

另一种方法是用 multiprocessing.pool.ThreadPool,这个接口和 multiprocessing.Pool 一样,但是用的是 threading

from multiprocessing.pool import ThreadPool

pool = ThreadPool(num_workers)

def req(url):
    res = pool.apply(requests.get, args=(url,))
    # ...
め可乐爱微笑 2022-09-09 00:16:31

协程
生产者消费者模式

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文