Lazulitecn 2021-11-26 16:05 采纳率: 84.8%
浏览 23
已结题

Python多进程队列怎么使用呢?需要共同执行而不是同时执行清单内容

请问多进程队列怎么使用呢?比如我有一个12个网站的清单需要request.get,我创建4个进程去共同操作


def getinfo(q):
    for i in range(12):
        print(i)
        time.sleep(5)

if __name__ == "__main__":
    q = Queue(4)
    p1 = Process(target=getinfo, args=(q,))
    p2 = Process(target=getinfo, args=(q,))
    p3 = Process(target=getinfo, args=(q,))
    p4 = Process(target=getinfo, args=(q,))
    p1.start()
    p2.start()
    p3.start()
    p4.start()
    p1.join()
    p2.join()
    p3.join()
    p4.join()

现在的结果:
get网站1
get网站1
get网站1
get网站1
get网站2
get网站2
get网站2
get网站2

因为响应不同,4个共同操作,任意一个完成后,下一个就接着执行,需要结果:
get网站1
get网站2
get网站3
get网站4
get网站6
get网站7
get网站5
get网站8

  • 写回答

1条回答 默认 最新

  • 於黾 2021-11-26 16:14
    关注

    你12个网站对应12个url,你把url放进list里,循环丢给进程
    因为你进程只开了4个,所以有进程执行完毕了,队列里会自动有新进程开始执行,直到队列变空
    你现在这样给每个进程分配一样的任务,循环去访问12个网站,那不是闹呢么

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月4日
  • 已采纳回答 11月26日
  • 创建了问题 11月26日

悬赏问题

  • ¥15 基于FOC驱动器,如何实现卡丁车下坡无阻力的遛坡的效果
  • ¥15 IAR程序莫名变量多重定义
  • ¥15 (标签-UDP|关键词-client)
  • ¥15 关于库卡officelite无法与虚拟机通讯的问题
  • ¥100 已有python代码,要求做成可执行程序,程序设计内容不多
  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助
  • ¥15 STM32控制MAX7219问题求解答