大家都知道python经常被用来做爬虫,用来在互联网上抓取我们需要的信息。

使用Python做爬虫,需要用到一些包:

requests

urllib

BeautifulSoup

等等,关于python工具的说明,请看这里:Python 爬虫的工具列表今天介绍一个简单的爬虫,网络聊天流行斗图,偶然发现一个网站www.doutula.com.上面的图片挺搞笑的,可以摘下来使用。

我们来抓一下“最新斗图表情”:

看到下面有分页,分析下他的分页url格式:

不难发现分页的url是:https://www.doutula.com/photo/list/?page=x

一步步来:

先简单抓取第一页上的图片试试:

将抓取的图片重新命名,存储在项目根目录的images目录下:

分析网页上img格式:

好了,我们开始准备写程序吧:使用pycharm IDE创建项目

我们抓包会用到:requests 和urllib,需要先安装这些包:file->default settings

点击右侧绿色的+号:

同样的引入:BeautifulSoup,lxml

接下来就可以引入这些包,然后开始开发了:

  1. import requests
  2. from bs4 import BeautifulSoup
  3. import urllib
  4. import os
  5.  
  6. url = 'https://www.doutula.com/photo/list/?page=1'
  7. response = requests.get(url)
  8. soup = BeautifulSoup(response.content,'lxml')
  9. img_list = soup.find_all('img',attrs={'class':'img-responsive lazy image_dta'})
  10. i=0
  11. for img in img_list:
  12. print (img['data-original'])
  13. src = img['data-original']
  14. #src = '//ws1.sinaimg.cn/bmiddle/9150e4e5ly1fjlv8kgzr0g20ae08j74p.gif'
  15. if not src.startswith('http'):
  16. src= 'http:'+src
  17. filename = src.split('/').pop()
  18. fileextra = filename.split('.').pop()
  19. filestring = i+'.'+fileextra
  20. path = os.path.join('images',filestring)
  21. # 下载图片
  22. headers = {
  23. 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',
  24. 'Accept-Encoding': 'gzip, deflate, sdch',
  25. 'Accept-Language': 'zh-CN,zh;q=0.8',
  26. 'Connection': 'keep-alive',
  27. 'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.235'
  28. }
  29. #urllib.request.urlretrieve(url,path,header)
  30. req = urllib.request.Request(url=src, headers=headers)
  31. cont = urllib.request.urlopen(req).read()
  32. root = r""+path+""
  33. f=open(root,'wb')
  34. f.write(cont)
  35. f.close
  36. i += 1

注意:

  1.请求的时候需要加上header,伪装成浏览器请求,网站大多不允许抓取。

抓完一页的图片,我们试着抓取多页的图片:这里试下抓取第一页和第二页的图片

  1. import requests
  2. from bs4 import BeautifulSoup
  3. import urllib
  4. import os
  5. import datetime
  6. #begin
  7. print (datetime.datetime.now())
  8. URL_LIST = []
  9. base_url = 'https://www.doutula.com/photo/list/?page='
  10. for x in range(1,3):
  11. url = base_url+str(x)
  12. URL_LIST.append(url)
  13. i = 0
  14. for page_url in URL_LIST:
  15. response = requests.get(page_url)
  16. soup = BeautifulSoup(response.content,'lxml')
  17. img_list = soup.find_all('img',attrs={'class':'img-responsive lazy image_dta'})
  18. for img in img_list: #一页上的图片
  19. print (img['data-original'])
  20. src = img['data-original']
  21. if not src.startswith('http'):
  22. src= 'http:'+src
  23. filename = src.split('/').pop()
  24. fileextra = filename.split('.').pop()
  25. filestring = str(i)+'.'+fileextra
  26. path = os.path.join('images',filestring)
  27. # 下载图片
  28. headers = {
  29. 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',
  30. 'Accept-Encoding': 'gzip, deflate, sdch',
  31. 'Accept-Language': 'zh-CN,zh;q=0.8',
  32. 'Connection': 'keep-alive',
  33. 'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.235'
  34. }
  35. #urllib.request.urlretrieve(url,path,header)
  36. req = urllib.request.Request(url=src, headers=headers)
  37. cont = urllib.request.urlopen(req).read()
  38. root = r""+path+""
  39. f=open(root,'wb')
  40. f.write(cont)
  41. f.close
  42. i += 1
  43. #end
  44. print (datetime.datetime.now())

这样我们就完成了多页图片的抓取,但是貌似有点慢啊,要是抓所有的,那估计得花一点时间了。
python是支持多线程的,我们可以利用多线程来提高速度:

分析一下这是怎么样的一个任务:我们将网页地址全部存储到一个list中,所有的图片地址也存储在一个list中,然后按顺序来取图片地址,再依次下载

这样类似一个:多线程有序操作的过程,就是“消费者生产者模式”,使用list加锁来实现队列(FIFO先进先出)。

一起回忆一下队列的特点吧:

看代码吧:我们下载第一页到第99页的图片

  1. import requests
  2. from bs4 import BeautifulSoup
  3. import urllib
  4. import os
  5. import datetime
  6. import threading
  7. import time
  8.  
  9. i = 0
  10. FACE_URL_LIST = []
  11. URL_LIST = []
  12. base_url = 'https://www.doutula.com/photo/list/?page='
  13. for x in range(1,100):
  14. url = base_url+str(x)
  15. URL_LIST.append(url)
  16. #初始化锁
  17. gLock = threading.Lock()
  18.  
  19. #生产者,负责从页面中提取表情图片的url
  20. class producer(threading.Thread):
  21. def run(self):
  22. while len(URL_LIST)>0:
  23. #访问时需要加锁
  24. gLock.acquire()
  25. cur_url = URL_LIST.pop()
  26. #使用完后及时释放锁,方便其他线程使用
  27. gLock.release()
  28. response = requests.get(cur_url)
  29. soup = BeautifulSoup(response.content, 'lxml')
  30. img_list = soup.find_all('img', attrs={'class': 'img-responsive lazy image_dta'})
  31. gLock.acquire()
  32. for img in img_list: # 一页上的图片
  33. print(img['data-original'])
  34. src = img['data-original']
  35. if not src.startswith('http'):
  36. src = 'http:' + src
  37. FACE_URL_LIST.append(src)
  38. gLock.release()
  39. time.sleep(0.5)
  40.  
  41. #消费者,负责从FACE_URL_LIST中取出url,下载图片
  42. class consumer(threading.Thread):
  43. def run(self):
  44. global i
  45. j=0
  46. print ('%s is running' % threading.current_thread)
  47. while True:
  48. #上锁
  49. gLock.acquire()
  50. if len(FACE_URL_LIST) == 0:
  51. #释放锁
  52. gLock.release()
  53. j = j + 1
  54. if (j > 1):
  55. break
  56. continue
  57. else:
  58. #从FACE_URL_LIST中取出url,下载图片
  59. face_url = FACE_URL_LIST.pop()
  60. gLock.release()
  61. filename = face_url.split('/').pop()
  62. fileextra = filename.split('.').pop()
  63. filestring = str(i) + '.' + fileextra
  64. path = os.path.join('images', filename)
  65. #path = os.path.join('images', filestring)
  66. # 下载图片
  67. headers = {
  68. 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',
  69. 'Accept-Encoding': 'gzip, deflate, sdch',
  70. 'Accept-Language': 'zh-CN,zh;q=0.8',
  71. 'Connection': 'keep-alive',
  72. 'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.235'
  73. }
  74. # urllib.request.urlretrieve(url,path,header)
  75. req = urllib.request.Request(url=face_url, headers=headers)
  76. cont = urllib.request.urlopen(req).read()
  77. root = r"" + path + ""
  78. f = open(root, 'wb')
  79. f.write(cont)
  80. f.close
  81. print(i)
  82. i += 1
  83.  
  84. if __name__ == '__main__': #在本文件内运行
  85. # begin
  86. print(datetime.datetime.now())
  87. #2个生产者线程从页面抓取表情链接
  88. for x in range(2):
  89. producer().start()
  90.  
  91. #5个消费者线程从FACE_URL_LIST中提取下载链接,然后下载
  92. for x in range(5):
  93. consumer().start()
  94. #end
  95. print (datetime.datetime.now())

看看images文件夹下多了好多图,以后斗图不用愁了!

OK,到此算是结束了。最后为python宣传一下。

零基础教你写python爬虫的更多相关文章

  1. [原创]手把手教你写网络爬虫(7):URL去重

    手把手教你写网络爬虫(7) 作者:拓海 摘要:从零开始写爬虫,初学者的速成指南! 封面: 本期我们来聊聊URL去重那些事儿.以前我们曾使用Python的字典来保存抓取过的URL,目的是将重复抓取的UR ...

  2. [原创]手把手教你写网络爬虫(4):Scrapy入门

    手把手教你写网络爬虫(4) 作者:拓海 摘要:从零开始写爬虫,初学者的速成指南! 封面: 上期我们理性的分析了为什么要学习Scrapy,理由只有一个,那就是免费,一分钱都不用花! 咦?怎么有人扔西红柿 ...

  3. [原创]手把手教你写网络爬虫(5):PhantomJS实战

    手把手教你写网络爬虫(5) 作者:拓海 摘要:从零开始写爬虫,初学者的速成指南! 封面: 大家好!从今天开始,我要与大家一起打造一个属于我们自己的分布式爬虫平台,同时也会对涉及到的技术进行详细介绍.大 ...

  4. 教你用python爬虫监控教务系统,查成绩快人一步!

    教你用python爬虫监控教务系统,查成绩快人一步!这几天考了大大小小几门课,教务系统又没有成绩通知功能,为了急切想知道自己挂了多少门,于是我写下这个脚本. 设计思路:设计思路很简单,首先对已有的成绩 ...

  5. 零基础写python爬虫之使用Scrapy框架编写爬虫

    网络爬虫,是在网上进行数据抓取的程序,使用它能够抓取特定网页的HTML数据.虽然我们利用一些库开发一个爬虫程序,但是使用框架可以大大提高效率,缩短开发时间.Scrapy是一个使用Python编写的,轻 ...

  6. 零基础小白怎么用Python做表格?

    用Python操作Excel在工作中还是挺常用的,因为毕竟不懂Excel是一个用户庞大的数据管理软件.本文用Python3!在给大家分享之前呢,小编推荐一下一个挺不错的交流宝地,里面都是一群热爱并在学 ...

  7. [零基础学pythyon]安装python编程环境

    不论什么高级语言都是须要一个自己的编程环境的,这就好比写字一样,须要有纸和笔,在计算机上写东西.也须要有文字处理软件,比方各种名称的OFFICE.笔和纸以及office软件,就是写东西的硬件或软件.总 ...

  8. 致初学者:零基础如何学好,Python这门编程语言?

    前言对于很多Python这门编程语言的初学者,往往会面临以下问题: Python2和Python3我该学习哪一个?是否要安装Linux系统学习Python?Python3有各种版本我该安装哪一个?那么 ...

  9. Python零基础学习系列之三--Python编辑器选择

    上一篇文章记录了怎么安装Python环境,同时也成功的在电脑上安装好了Python环境,可以正式开始自己的编程之旅了.但是现在又有头疼的事情,该用什么来写Python程序呢,该用什么来执行Python ...

随机推荐

  1. Java 多线程笔记

    资料来源于网络,仅供参考学习.   1.A Java program ends when all its threads finish (more specifically, when all its ...

  2. rpc之thrift

    rpc之thrift 一.介绍 thrift是一个rpc(remove procedure call)框架,可以实现不同的语言(java.c++.js.python.ruby.c#等)之间的相互调用. ...

  3. java web 之 AJAX用法

    AJAX :Asynchronous JavaScript And XML 指异步 JavaScript 及 XML一种日渐流行的Web编程方式 Better Faster User-Friendly ...

  4. 设计模式学习(三): 装饰者模式 (附C#实现)

    需求 做一个咖啡店的订单系统. 买咖啡时,可以要求加入各种调料,如奶,豆浆,摩卡等.咖啡店会根据调料的不同收取不同的费用.订单系统要考虑这些. 初版设计 然后下面就是所有的咖啡....: cost方法 ...

  5. centos下卸载OpenJDK 并安装sun的jdk

    centos下卸载OpenJDK 并安装sun的jdk 第一步:查看并卸载CentOS自带的OpenJDK 安装好的CentOS会自带OpenJdk,用命令 java -version ,我这里显示下 ...

  6. windows系统安装securtCRT

    说明:securtCRT可以ssh liunx主机,或者网络设备,如路由器,交换机,防火墙等设备,很多新手不会安装,因为正版要钱啊,对于小老百姓,还是用破解的吧 不说废话,开始搞起来. 软件下载链接: ...

  7. flask-日料网站搭建

    引言:想使用python的flask框架搭建一个日料网站,主要包含web架构,静态页面,后台系统,交互. 本节知识:搭建web目录,目前正在copy网站. python环境:python2.7,fla ...

  8. Spring Boot快速入门(四):使用jpa进行数据库操作

    原文地址:https://lierabbit.cn/articles/5 添加依赖 新建项目选择web,JPA,MySQL三个依赖 对于已存在的项目可以在bulid.gradle加入,spring b ...

  9. spring官方学习地址

    1.http://projects.spring.io/spring-framework/ 2.https://github.com/spring-projects/spring-mvc-showca ...

  10. 应用服务器GC回收常见问题总结

    近一段时间多次发现因GC问题造成系统性能问题(应用服务间歇性响应缓慢.应用服务器CPU占用较高等),在此总结一下: 1.代码中直接调用GC.Collect() 2.字符串等操作频繁的内存申请 3.频繁 ...