python练手项目——爬取网页美女图片

1.下载数据

动态网页

下载数据的模块

2.解析数据

正则表达式说明

3.保存数据

1.下载数据

首先打开要爬的网站,分析URL,每打开一个网页看URL有什么变化,有可能带上上个网页的某个数据,例如xxID之类,那么我们就需要在上一个页面分析HTML,找到对应的数据。如果网页源码找不到,可能是ajax异步加载,去xhr里去找。

有的网站做了反爬的处理,可以添加User-Agent :判断浏览器


self.user_agent = 'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)'
# 初始化 headers
self.headers = {'User-Agent': self.user_agent}

如果不行,在Chrome上按F12分析请求头、请求体,看需不需要添加别的信息,例如有的网址添加了referer当前网页的来源,那么我们在请求的时候就可以带上。按Ctrl + Shift + C,可以定位元素在HTML上的位置

动态网页

有一些网页是动态网页,我们得到网页的时候,数据还没请求到呢,当然什么都提取不出来,用Python 解决这个问题只有两种途径:直接从JavaScript 代码里采集内容,或者用Python 的第三方库运行JavaScript,直接采集你在浏览器里看到的页面。

1.找请求,看返回的内容,网页的内容可能就在这里。然后可以复制请求,复杂的网址中,有些乱七八糟的可以删除,有意义的部分保留。切记删除一小部分后先尝试能不能打开网页,如果成功再删减,直到不能删减。

2.Selenium:是一个强大的网络数据采集工具(但是速度慢),其最初是为网站自动化测试而开发的。近几年,它还被广泛用于获取精确的网站快照,因为它们可以直接运行在浏览器上。Selenium 库是一个在WebDriver上调用的API。有点儿像可WebDriver以加载网站的浏览器,但是它也可以像BeautifulSoup对象一样用来查找页面元素,与页面上的元素进行交互(发送文本、点击等),以及执行其他动作来运行网络爬虫。

PhantomJS:是一个“无头”(headless)浏览器。它会把网站加载到内存并执行页面上的JavaScript,但是它不会向用户展示网页的图形界面。把Selenium和PhantomJS 结合在一起,就可以运行一个非常强大的网络爬虫了,可以处理cookie、JavaScript、header,以及任何你需要做的事情。

下载数据的模块

下载数据的模块有urllib、urllib2及Requests

Requests相比其他俩个的话,支持HTTP连接保持和连接池,支持使用cookie保持会话,支持文件上传,支持自 动确定响应内容的编码,支持国际化的 URL 和 POST数据自动编码,而且api相对来说也简单,但是requests直接使用不能异步调用,速度慢。


html = requests.get(url, headers=headers)   #没错,就是这么简单

urllib2以我爬取淘宝的妹子例子来说明


user_agent = 'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)'
headers = {'User-Agent': user_agent}
# 注意:form data请求参数
params = 'q&viewFlag=A&sortType=default&searchStyle=&searchRegion=city%3A&searchFansNum=&currentPage=1&pageSize=100'def getHome():url = 'https://mm.taobao.com/tstar/search/tstar_model.do?_input_charset=utf-8'req = urllib2.Request(url, headers=headers)# decode(’utf - 8’)解码   把其他编码转换成unicode编码# encode(’gbk’) 编码  把unicode编码转换成其他编码# ”gbk”.decode(’gbk’).encode(’utf - 8')# unicode = 中文# gbk = 英文# utf - 8 = 日文# 英文一 > 中文一 > 日文,unicode相当于转化器html = urllib2.urlopen(req, data=params).read().decode('gbk').encode('utf-8')# json转对象peoples = json.loads(html)for i in peoples['data']['searchDOList']:#去下一个页面获取数据getUseInfo(i['userId'], i['realName'])

2.解析数据

解析数据也有很多方式,我只看了beautifulsoup和正则,这个例子是用正则来解析的


def getUseInfo(userId, realName):url = 'https://mm.taobao.com/self/aiShow.htm?userId=' + str(userId)req = urllib2.Request(url)html = urllib2.urlopen(req).read().decode('gbk').encode('utf-8')pattern = re.compile('<img.*?src=(.*?)/>', re.S)items = re.findall(pattern, html)x = 0for item in items:if re.match(r'.*(.jpg")$', item.strip()):tt = 'http:' + re.split('"', item.strip())[1]down_image(tt, x, realName)x = x + 1print('下载完毕')

正则表达式说明

match:匹配string 开头,成功返回Match object, 失败返回None,只匹配一个。

search:在string中进行搜索,成功返回Match object, 失败返回None, 只匹配一个。

findall:在string中查找所有 匹配成功的组, 即用括号括起来的部分。返回list对象,每个list item是由每个匹配的所有组组成的list。

1).? 是一个固定的搭配,*.**和代表可以匹配任意无限多个字符,加上?表示使用非贪婪模式进行匹配,也就是我们会尽可能短地做匹配     2)(.?)代表一个分组,如果有5个(.*?)就说明匹配了五个分组

3) 正则表达式中,“.”的作用是匹配除“\n”以外的任何字符,也就是说,它是在一行中进行匹配。这里的“行”是以“\n”进行区分的。HTML标签每行的末尾有一个“\n”,不过它不可见。如果不使用re.S参数,则只在每一行内进行匹配,如果一行没有,就换下一行重新开始,不会跨行。而使用re.S参数以后,正则表达式会将这个字符串作为一个整体,将“\n”当做一个普通的字符加入到这个字符串中,在整体中进行匹配。

3.保存数据

数据解析后可以保存到文件或数据库中,这个例子是保存到了文件中,很简单了。


def down_image(url, filename, realName):req = urllib2.Request(url=url)folder = 'e:\\images\\%s' % realNameif os.path.isdir(folder):passelse:os.makedirs(folder)f = folder + '\\%s.jpg' % filenameif not os.path.isfile(f):print fbinary_data = urllib2.urlopen(req).read()with open(f, 'wb') as temp_file:temp_file.write(binary_data)

这是保存下来的爬取美女图片,看到了意想不到的场景美女图片方法,如有不足之处或更多技巧,欢迎指教补充。愿本文的分享对您之后爬虫有所帮助。谢谢~

编辑排版:筱筱   原创:不想秃头的晨晨

方法教程 | Python爬虫:爬取美女图片,看到了意想不到的场景美女图片相关推荐

  1. python爬虫爬取百度贴吧图片,requests方法

    每天一点点,记录学习 近期爬虫项目,看完请点赞哦---: 1:python 爬取菜鸟教程python100题,百度贴吧图片反爬虫下载,批量下载 2:python爬虫爬取百度贴吧图片,requests方 ...

  2. 使用Python爬虫爬取网络美女图片

    代码地址如下: http://www.demodashi.com/demo/13500.html 准备工作 安装python3.6 略 安装requests库(用于请求静态页面) pip instal ...

  3. Python爬虫爬取美女写真实例

    Python爬虫爬取美女写真实例 微信关注公众号:夜寒信息 致力于为每一位用户免费提供更优质技术帮助与资源供给,感谢支持!     这是我写的一个较为简单的爬虫代码,用于爬取美女写真(咳咳,当然是正规 ...

  4. Python爬虫爬取微信朋友圈的方法,感兴趣的朋友可以了解下

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 小雨 | 作者 python教程 | 来源 接下来,我们将实现微信朋友圈的 ...

  5. 运用Python爬虫爬取一个美女网址,爬取美女图

    运用Python爬虫爬取一个美女网址,爬取美女图 要运用到的python技术: 导入库 1.request 发送请求,从服务器获取数据 2.BeautifulSoup 用来解析整个网页的源代码 imp ...

  6. Python爬虫爬取煎蛋网图片代码实例

    这篇文章主要介绍了Python爬虫爬取煎蛋网图片代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 今天,试着爬取了煎蛋网的图片. 用到的包: ...

  7. Python爬虫爬取Twitter视频、文章、图片

    Python爬虫爬取Twitter视频.文章.图片 Twitter的Python爬虫 https://github.com/bisguzar/twitter-scraper 2.2k星标 (2020. ...

  8. Python爬虫爬取王者荣耀英雄人物高清图片

    Python爬虫爬取王者荣耀英雄人物高清图片 实现效果: 网页分析 从第一个网页中,获取每个英雄头像点击后进入的新网页地址,即a标签的 href 属性值: 划线部分的网址是需要拼接的 在每个英雄的具体 ...

  9. Python爬虫爬取相关图片

    简要的实现实现Python爬虫爬取百度贴吧页面上的图片,下面的网页就是本篇博客所要爬的网页,当然看到的只是其中的一部分图片,是所要爬取的页面, 而下图则是最终的爬取的图片: 接下来就简要的讲讲爬取的整 ...

  10. 初始python爬虫-爬取彼岸图单张到全部图片

    初始python爬虫-爬取彼岸图单张到全部图片 1.单张图片爬取 2.一页图片 3.多页图片 彼岸图链接: https://pic.netbian.com/new/ 用到的库: import requ ...

最新文章

  1. HBase编程 API入门系列之put(客户端而言)(1)
  2. CH Round #30 摆花[矩阵乘法]
  3. lucene join解决父子关系索引
  4. 三星a60android9,三星A6058官方国行安卓9固件rom线刷升级包:CHM-A6058ZMU2BSC9
  5. rmmod无法卸载驱动_笔记:linux驱动开发(1、了解内核模块)
  6. vue搜索好友_Vue实现类似通讯录功能(中)
  7. 输入广义表建立子女兄弟链表示的树
  8. IE7下动态创建Iframe时,去除边框
  9. zabbix详解(五)——zabbix配置文件详解
  10. 小学生学计算机动画,小学生电脑绘画软件_电脑绘画之“卡通小熊”
  11. “只要就“其实是废话,没有任何用处
  12. 十年深圳人,是真的吗?
  13. pytorch官网不支持cuda10.2
  14. 胡彦斌and音乐密码 MUSIC CODE
  15. Python打印车次信息
  16. rtsp 报文转发_stp技术回顾和rstp经典笔记
  17. 渗透测试的灵魂:信息收集
  18. 山东大学移动信息门户03
  19. 怎么用java调用快递接口查询和寄件等功能java-demo
  20. http转义与url编码

热门文章

  1. MessageBox--获知点击确认还是取消?
  2. 对隐秘的角落电视剧的感悟以及认识
  3. python微信抢票脚本_春节到了 教你使用python来抢票回家
  4. 北京消费扶贫双创中心启用 2000余种特色产品长期展销
  5. 黄牛用高性能服务器抢票,还在找黄牛“加速”抢票?成功抢票旅客:黄牛让我去12306候补...
  6. 80后的青春里,总有散不去的周杰伦
  7. Linux的进程管理之进程与线程—2
  8. git简明教程 - 协作篇
  9. 最后的最后的一场考试
  10. 安卓开发 之小白养成-Android环境搭建 二