Python3多线程爬虫实例讲解代码


Posted in Python onJanuary 05, 2018

多线程概述

多线程使得程序内部可以分出多个线程来做多件事情,充分利用CPU空闲时间,提升处理效率。python提供了两个模块来实现多线程thread 和threading ,thread 有一些缺点,在threading 得到了弥补。并且在Python3中废弃了thread模块,保留了更强大的threading模块。

使用场景

在python的原始解释器CPython中存在着GIL(Global Interpreter Lock,全局解释器锁),因此在解释执行python代码时,会产生互斥锁来限制线程对共享资源的访问,直到解释器遇到I/O操作或者操作次数达到一定数目时才会释放GIL。所以,虽然CPython的线程库直接封装了系统的原生线程,但CPython整体作为一个进程,同一时间只会有一个获得GIL的线程在跑,其他线程则处于等待状态。这就造成了即使在多核CPU中,多线程也只是做着分时切换而已。

如果你的程序是CPU密集型,多个线程的代码很有可能是线性执行的。所以这种情况下多线程是鸡肋,效率可能还不如单线程因为有上下文切换开销。但是如果你的代码是IO密集型,涉及到网络、磁盘IO的任务都是IO密集型任务,多线程可以明显提高效率,例如多线程爬虫,多线程文件处理等等

多线程爬虫

多线程爬虫的代码实例

注: 以下代码在python3下运行通过, python2版本差异较大,不能运行成功,如需帮助请下方留意。

# coding=utf-8
import threading, queue, time, urllib
from urllib import request
baseUrl = 'http://www.pythontab.com/html/pythonjichu/'
urlQueue = queue.Queue()
for i in range(2, 10):
 url = baseUrl + str(i) + '.html'
 urlQueue.put(url)
 #print(url)
def fetchUrl(urlQueue):
 while True:
  try:
   #不阻塞的读取队列数据
   url = urlQueue.get_nowait()
   i = urlQueue.qsize()
  except Exception as e:
   break
  print ('Current Thread Name %s, Url: %s ' % (threading.currentThread().name, url))
  try:
   response = urllib.request.urlopen(url)
   responseCode = response.getcode()
  except Exception as e:
   continue
  if responseCode == 200:
   #抓取内容的数据处理可以放到这里
   #为了突出效果, 设置延时
   time.sleep(1)
if __name__ == '__main__':
 startTime = time.time()
 threads = []
 # 可以调节线程数, 进而控制抓取速度
 threadNum = 4
 for i in range(0, threadNum):
  t = threading.Thread(target=fetchUrl, args=(urlQueue,))
  threads.append(t)
 for t in threads:
  t.start()
 for t in threads:
  #多线程多join的情况下,依次执行各线程的join方法, 这样可以确保主线程最后退出, 且各个线程间没有阻塞
  t.join()
 endTime = time.time()
 print ('Done, Time cost: %s ' % (endTime - startTime))

运行结果:

1个线程时:

Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/2.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/3.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/4.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/5.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/6.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/7.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/8.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/9.html 
Done, Time cost: 8.182249069213867

2个线程时:

Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/2.html 
Current Thread Name Thread-2, Url: http://www.pythontab.com/html/pythonjichu/3.html 
Current Thread Name Thread-2, Url: http://www.pythontab.com/html/pythonjichu/4.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/5.html 
Current Thread Name Thread-2, Url: http://www.pythontab.com/html/pythonjichu/6.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/7.html 
Current Thread Name Thread-2, Url: http://www.pythontab.com/html/pythonjichu/8.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/9.html 
Done, Time cost: 4.0987958908081055

3个线程时:

Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/2.html 
Current Thread Name Thread-2, Url: http://www.pythontab.com/html/pythonjichu/3.html 
Current Thread Name Thread-3, Url: http://www.pythontab.com/html/pythonjichu/4.html 
Current Thread Name Thread-4, Url: http://www.pythontab.com/html/pythonjichu/5.html 
Current Thread Name Thread-2, Url: http://www.pythontab.com/html/pythonjichu/6.html 
Current Thread Name Thread-4, Url: http://www.pythontab.com/html/pythonjichu/7.html 
Current Thread Name Thread-1, Url: http://www.pythontab.com/html/pythonjichu/9.html 
Current Thread Name Thread-3, Url: http://www.pythontab.com/html/pythonjichu/8.html 
Done, Time cost: 2.287320137023926

通过调节线程数可以看到,执行时间会随着线程数的增加而缩短,抓取效率成正比增加。

总结:

Python多线程在IO密集型任务,多线程可以明显提高效率,CPU密集型任务不适合使用多线程处理。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python import自定义模块方法
Feb 12 Python
简化Python的Django框架代码的一些示例
Apr 20 Python
Python中类的初始化特殊方法
Dec 01 Python
python实现识别手写数字 python图像识别算法
Mar 23 Python
Python实现基于C/S架构的聊天室功能详解
Jul 07 Python
Python3.6.x中内置函数总结及讲解
Feb 22 Python
使用python画社交网络图实例代码
Jul 10 Python
Django错误:TypeError at / 'bool' object is not callable解决
Aug 16 Python
浅谈Django中的QueryDict元素为数组的坑
Mar 31 Python
Python标准库:内置函数max(iterable, *[, key, default])说明
Apr 25 Python
python3发送request请求及查看返回结果实例
Apr 30 Python
PyQt5-QDateEdit的简单使用操作
Jul 12 Python
python编写微信远程控制电脑的程序
Jan 05 #Python
使用python爬虫实现网络股票信息爬取的demo
Jan 05 #Python
简单实现python收发邮件功能
Jan 05 #Python
5款非常棒的Python工具
Jan 05 #Python
Python基于列表模拟堆栈和队列功能示例
Jan 05 #Python
Django 2.0版本的新特性抢先看!
Jan 05 #Python
微信跳一跳游戏python脚本
Apr 01 #Python
You might like
php学习笔记之基础知识
2014/11/08 PHP
基于win2003虚拟机中apache服务器的访问
2017/08/01 PHP
关于页面嵌入swf覆盖div层的问题的解决方法
2014/02/11 Javascript
Javascript Memoizer浅析
2014/10/16 Javascript
Javascript实现获取及设置光标位置的方法
2015/07/21 Javascript
Vue编写多地区选择组件
2017/08/21 Javascript
web3.js增加eth.getRawTransactionByHash(txhash)方法步骤
2018/03/15 Javascript
浅谈Vue页面级缓存解决方案feb-alive(上)
2019/04/14 Javascript
基于jQuery的时间戳与日期间的转化
2019/06/21 jQuery
基于webpack4+vue-cli3项目实现换肤功能
2019/07/17 Javascript
layer.alert回调函数执行关闭弹窗的实例
2019/09/11 Javascript
python删除列表内容
2015/08/04 Python
浅析Python中元祖、列表和字典的区别
2016/08/17 Python
python广度优先搜索得到两点间最短路径
2019/01/17 Python
详解Python locals()的陷阱
2019/03/26 Python
python自动化测试之如何解析excel文件
2019/06/27 Python
Python的numpy库下的几个小函数的用法(小结)
2019/07/12 Python
Python操作远程服务器 paramiko模块详细介绍
2019/08/07 Python
关于Python3 类方法、静态方法新解
2019/08/30 Python
ubuntu 安装pyqt5和卸载pyQt5的方法
2020/03/24 Python
python Cartopy的基础使用详解
2020/11/01 Python
世界上最大的糖果店:Dylan’s Candy Bar
2017/11/07 全球购物
美国专业汽车音响和移动电子产品零售商:Car Toys
2019/05/13 全球购物
什么是方法的重载
2013/06/24 面试题
vue+django实现下载文件的示例
2021/03/24 Vue.js
幼教个人求职信范文
2013/12/02 职场文书
2014年创卫实施方案
2014/02/18 职场文书
函授毕业个人自我评价
2014/02/20 职场文书
联谊会主持词
2014/03/26 职场文书
献爱心活动总结
2014/05/07 职场文书
2015年基层党支部工作总结
2015/05/21 职场文书
个人工作总结怎么写?
2019/04/09 职场文书
如何让2019年上半年的工作总结更出色!
2019/07/01 职场文书
您对思维方式了解多少?
2019/12/09 职场文书
导游词之绍兴柯岩古镇
2020/01/09 职场文书
Python turtle编写简单的球类小游戏
2022/03/31 Python