1. 首页
  2. Python

Python学习,多进程了解一下!学爬虫不会用多进程能行吗?

“u003Cdivu003Eu003Cblockquoteu003Eu003Cpu003Epython中的多线程其实并不是真正的多线程,如果想要充分地使用多核CPU的资源,在python中大部分情况需要使用多进程。Python提供了非常好用的多进程包multiprocessing,只需要定义一个函数,Python会完成其他所有事情。借助这个包,可以轻松完成从单进程到u003Cstrongu003E并发执行u003Cu002Fstrongu003E的转换u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpu003E本来想写多线程的,但是演示效果并不是很好,就改成进程了。u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F15329370905645e8dcfabd0″ img_width=”450″ img_height=”282″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E其实多进程没有我们想象的那么难,用几个小例子给大家分享一下!u003Cu002Fpu003Eu003Ch1u003E目录u003Cu002Fh1u003Eu003Culu003Eu003Cliu003E多进程的多种实现方法及效果演示:这段将通过几个小脚本实现多进程的效果u003Cu002Fliu003Eu003Cliu003E一个小爬虫实例,通过运行时间来查看进程对代码速度的影响u003Cu002Fliu003Eu003Cu002Fulu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002F153293735963869c72a31b9″ img_width=”459″ img_height=”273″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Ch1u003E多进程u003Cu002Fh1u003Eu003Cpu003E首先我们先做一个小脚本,就用turtle画4个同心圆吧!这样在演示多进程的时候比较直观。代码如下:u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F153291779410820032d60d6″ img_width=”464″ img_height=”359″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E这段代码,实现了画4个同心圆的效果,如果用多进程的话,我们稍微该写一下u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F1532917866213c02cc17c4c” img_width=”525″ img_height=”427″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E这里,启动4个进程,同时画圆,给个图大家感受一下!u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002F1532918099559607eb58652″ img_width=”1200″ img_height=”704″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E可以看到,这里直接生成4个画板同时画同心圆。如果还要在加进程的话,可以用pool进程池,注意pool有2个方法,建议用非阻塞的p.apply_async不要用阻塞的p.apply方法,p.apply_async会由系统自行判断并运行,比如指定4个进程运行5个任务,那么会在某一个进程运行完毕的同时自动开始第5个任务,而阻塞的p.apply方法会一次只运行一个进程。u003Cu002Fpu003Eu003Cpu003E然后就是记得close()进程池,并用p.join()等待所有进程完成!相关代码如下u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F1532918849865765a5623ff” img_width=”404″ img_height=”159″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003EPool()里面不带参数会自动适应电脑本身内核数量,这里我设置9个进程同时进行!来看看效果u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002F1532919033436c77ead46fb” img_width=”1200″ img_height=”704″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E可以看到,同时进行了9个画图的进程,但是同样的,有明显的卡顿感!当然,我们也可以用map函数来写多进程,先修改下代码u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F1532919409886a1bc97c9ae” img_width=”412″ img_height=”277″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E这次不画4个同心圆了,我们让它4个进程各画一个圆,来看看效果u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002F15329195317204ef7315558″ img_width=”1200″ img_height=”704″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E为了演示效果,多加了点间隔时间,并把cir函数的参数改为1个,这样便于生成元组列表!可以看到,有了明显的卡顿,电脑不好,大家看看效果就行了u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F1532937296948f8aee546ba” img_width=”405″ img_height=”288″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Ch1u003E写个简单的多进程爬虫u003Cu002Fh1u003Eu003Cpu003E做一个小爬虫,加入运行时间,先上一个不使用进程的代码:u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F1532936478007b6407defcc” img_width=”580″ img_height=”394″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F1532936490268c77740ce6f” img_width=”549″ img_height=”273″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E在修改下多进程,直接修改25,26行代码即可u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F15329365898188744ccf67a” img_width=”597″ img_height=”106″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002F153293662267556ab69df3b” img_width=”477″ img_height=”193″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E可以看到,速度提高了1倍多,当然,并不是说只能提高一倍,而是我的代码太简单了,只是从网站抓取字符串打印出来,响应速度很快,导致提升的倍率并没有我们想象的那么高,如果大家有兴趣,可以尝试一下,基本上可以提升到进程数的倍率,也就是说,不超过电脑核心数量,且没有其他外因(比如网络响应速度等等)的情况下,用4进程可以提升接近4倍的速度!u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002F1532937342496433593e7cc” img_width=”450″ img_height=”278″ alt=”Python学习,多进程了解一下!学爬虫不会用多进程能行吗?” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Ch1u003E后记u003Cu002Fh1u003Eu003Cpu003E在学习的过程中,难免会遇到很高深并且很难理解的知识点,我们可以先尝试去简化理解它,比如多进程,它本身还有进程池、进程间通讯、守护进程、进程类(重写run方法)、进程锁、进程队列、管道、信号量等等功能或知识点,这里都没有涉及,不过这并不影响我们使用简单的多进程写代码!但遇到更复杂的简单的多进程搞不定的情况的时候,要知道什么功能可以适用,并且去接触、学习、掌握它,这就足够了!希望能对大家有所帮助!u003Cu002Fpu003Eu003Cu002Fdivu003E”

原文始发于:Python学习,多进程了解一下!学爬虫不会用多进程能行吗?

主题测试文章,只做测试使用。发布者:敢吻,转转请注明出处:http://www.cxybcw.com/13258.html

联系我们

13687733322

在线咨询:点击这里给我发消息

邮件:1877088071@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code