Lazulitecn 2023-01-16 16:38 采纳率: 84.8%
浏览 40
已结题

Python怎么一个进程生产,多个进程队列处理生产出来的内容呢?

因为get_url比save_pic快,所以需要将获取到的直链分配给队列执行提升效率。
尝试了Queue的put,get,但是不知道为什么只执行对应进程数的get_url()部分,而save_pic部分并没有执行。

def get_url()
  # 读取excel内的链接,操作后生成下载直链
  ......
  if pic_url.status_code == 200:
    save_pic(down_url, pic_name, pic_id)
  elif pic_url.status_code == 400:
    # 重新获取下载直链
    ......
    save_pic(down_url, pic_name, pic_id)
  else:
    pass

def save_pic(down_url, pic_name, pic_id)
  # 判断并创建对应需储存的目录
  #  with open储存图片
  • 写回答

3条回答 默认 最新

  • m0_54204465 2023-01-16 16:43
    关注

    您可以使用Python的多进程库multiprocessing来实现这个需求。在这种情况下,您可以使用一个进程负责获取URL,并将获取的URL放入一个队列中。然后,您可以使用多个进程并行地从队列中获取URL并执行save_pic()函数。

    下面是一个示例代码,该代码使用4个进程来并行获取URL并执行save_pic()函数:

    from multiprocessing import Process, Queue
    
    def get_url(url_queue):
        # 读取excel内的链接,获取下载直链
        while True:
            # 获取URL
            url = ...
            url_queue.put(url)
    
    def save_pic(url_queue):
        while True:
            url = url_queue.get()
            # 判断并创建对应需储存的目录
            # with open储存图片
    
    if __name__ == '__main__':
        url_queue = Queue()
        get_url_process = Process(target=get_url, args=(url_queue,))
        get_url_process.start()
        save_pic_processes = []
        for i in range(4):
            p = Process(target=save_pic, args=(url_queue,))
            save_pic_processes.append(p)
            p.start()
        get_url_process.join()
        for p in save_pic_processes:
            p.join()
    
    

    这样,get_url()进程就会不断地获取URL并将它们放入队列中,而4个save_pic()进程则会并行地从队列中获取URL并执行save_pic()函数。这样可以提高程序的性能。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 1月24日
  • 已采纳回答 1月16日
  • 修改了问题 1月16日
  • 修改了问题 1月16日
  • 展开全部

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效