网页爬虫 - python的多进程怎么配合requests
问题描述
这是单进程顺序执行的代码:
import requests,time,os,randomdef img_down(url): with open('{}'.format(str(random.random())+os.path.basename(url)),'wb') as fob:fob.write(requests.get(url).content)urllist=[]with open('urllist.txt','r+') as u: for a in u.readlines():urllist.append(a.strip())s=time.clock()for i in range(len(urllist)): img_down(urllist[i])e=time.clock()print ('time: %d' % (e-s))
这是多进程的代码:
from multiprocessing import Poolimport requests,os,time,randomdef img_down(url): with open('{}'.format(str(random.random())+os.path.basename(url)),'wb') as fob:fob.write(requests.get(url).content)if __name__=='__main__': urllist=[] with open('urllist.txt','r+') as urlfob:for s in urlfob.readlines(): urllist.append(s.strip()) s=time.clock() p=Pool() for i in range(len(urllist)):p.apply_async(img_down,args=(urllist[i],)) p.close() p.join() e=time.clock()print ('time: {}'.format(e-s))
但是单进程和多进程花费的时间几乎没区别,问题大概是requests阻塞IO,请问理解的对不对,代码该怎么修改达到多进程的目的?谢谢!
问题解答
回答1:写文件的瓶颈在磁盘IO,并不在CPU,你并行并没有多大作用,你可以试试不要写入文件再对比时间
回答2:Pool 不带参数的话 是采用 os.cpu_count() or 1如果是单核CPU,或者采集不到数量 就只有1个进程而已。
应该是这个原因。
相关文章:
1. docker网络端口映射,没有方便点的操作方法么?2. javascript - vue使用keep-alive不能保持滚动位置问题。3. python - Fiddler+Android模拟器抓取app,json数据被加密了,如何解析?4. MySQL的SELECT...FOR UPDATE究竟起什么作用5. python2.7为什么点击了"开始"按钮后,tkinter上的按钮,图中红色部分,再也点不动了?6. javascript - 一个字符串转换成数字,例子就是a="2,322.222",b=’1,211.21’,如何在angualr中执行相减7. javascript - 小米浏览器中,图片导致fixed定位的元素无法显示8. javascript - 在vuejs中如何根据变量去引用不同的css样式呢9. docker Toolbox在win10 家庭版中打开报错10. python - 如何在docker上部署pyspider

 网公网安备
网公网安备