python实现爬虫下载美女图片


Posted in Python onJuly 14, 2015

本次爬取的贴吧是百度的美女吧,给广大男同胞们一些激励

在爬取之前需要在浏览器先登录百度贴吧的帐号,各位也可以在代码中使用post提交或者加入cookie

爬行地址:http://tieba.baidu.com/f?kw=%E7%BE%8E%E5%A5%B3&ie=utf-8&pn=0

#-*- coding:utf-8 -*-
import urllib2
import re
import requests
from lxml import etree

这些是要导入的库,代码并没有使用正则,使用的是xpath,正则困难的童鞋可以尝试使用下

推荐各位先使用基本库来写,这样可以学习到更多

links=[]
#遍历url的地址
k=1


print u'请输入最后的页数:'
endPage=int(raw_input())

#最终的页数
(r'\d+(?=\s*页) 这是一个比较通用的正则抓取总页数的代码,当然最后要group

#这里是手动输入页数,避免内容太多

for j in range(0,endPage):
  url='http://tieba.baidu.com/f?kw=%E7%BE%8E%E5%A5%B3&ie=utf-8&pn='+str(j)


#页数的url地址
  html=urllib2.urlopen(url).read()







#读取首页的内容
  selector=etree.HTML(html)






#转换为xml,用于在接下来识别
  links=selector.xpath('//div/a[@class="j_th_tit"]/@href')



#抓取当前页面的所有帖子的url

#大家可以使用浏览器自带的源码查看工具,在指定目标处查看元素,这样更快捷

  for i in links:
    url1="http://tieba.baidu.com"+i


#因为爬取到的地址是相对地址,所以要加上百度的domain
    html2=urllib2.urlopen(url1).read()


#读取当前页面的内容
    selector=etree.HTML(html2)




#转换为xml用于识别
    link=selector.xpath('//img[@class="BDE_Image"]/@src')

#抓取图片,各位也可以更换为正则,或者其他你想要的内容

#此处就是遍历下载
    for each in link:
      #print each
      print u'正在下载%d'%k
      fp=open('image/'+str(k)+'.bmp','wb')


#下载在当前目录下 image文件夹内,图片格式为bmp
      image1=urllib2.urlopen(each).read()



#读取图片的内容
      fp.write(image1)








#写入图片
      fp.close()
      k+=1

#k就是文件的名字,每下载一个文件就加1

print u'下载完成!'

如果想要爬取其他站点的内容,大家可以参考一下

Python 相关文章推荐
python模拟新浪微博登陆功能(新浪微博爬虫)
Dec 24 Python
Python3.6简单操作Mysql数据库
Sep 12 Python
Python+PIL实现支付宝AR红包
Feb 09 Python
Python实现的redis分布式锁功能示例
May 29 Python
eclipse创建python项目步骤详解
May 10 Python
pycharm 安装JPype的教程
Aug 08 Python
python 统计文件中的字符串数目示例
Dec 24 Python
Keras: model实现固定部分layer,训练部分layer操作
Jun 28 Python
如何使用Cython对python代码进行加密
Jul 08 Python
在Python中字典按值排序的实现方法
Nov 12 Python
python opencv常用图形绘制方法(线段、矩形、圆形、椭圆、文本)
Apr 12 Python
python process模块的使用简介
May 14 Python
Python实现查找系统盘中需要找的字符
Jul 14 #Python
Python删除空文件和空文件夹的方法
Jul 14 #Python
Python实现批量将word转html并将html内容发布至网站的方法
Jul 14 #Python
Python删除windows垃圾文件的方法
Jul 14 #Python
Python简单计算文件夹大小的方法
Jul 14 #Python
Python判断直线和矩形是否相交的方法
Jul 14 #Python
Python下Fabric的简单部署方法
Jul 14 #Python
You might like
分享8个最佳的代码片段在线测试网站
2013/06/29 PHP
PHP批量删除jQuery操作
2017/07/23 PHP
PHP实现的pdo连接数据库并插入数据功能简单示例
2019/03/30 PHP
PHP设计模式之装饰器(装饰者)模式(Decorator)入门与应用详解
2019/12/13 PHP
jquery的颜色选择插件实例代码
2008/10/02 Javascript
用JavaScript显示随机图像或引用
2009/04/21 Javascript
javascript forEach通用循环遍历方法
2010/10/11 Javascript
JS运行耗时操作的延时显示方法
2010/11/19 Javascript
Nodejs学习笔记之入门篇
2015/04/16 NodeJs
深入浅出ES6新特性之函数默认参数和箭头函数
2016/08/01 Javascript
jQuery快速实现商品数量加减的方法
2017/02/06 Javascript
js实现带简单弹性运动的导航条
2017/02/22 Javascript
angular.js+node.js实现下载图片处理详解
2017/03/31 Javascript
react路由配置方式详解
2017/08/07 Javascript
详解基于Vue-cli搭建的项目如何和后台交互
2018/06/29 Javascript
微信小程序签到功能
2018/10/31 Javascript
javascript 设计模式之享元模式原理与应用详解
2020/04/08 Javascript
Js跳出两级循环方法代码实例
2020/09/22 Javascript
selenium3+python3环境搭建教程图解
2018/12/07 Python
Django中URL的参数传递的实现
2019/08/04 Python
python程序 创建多线程过程详解
2019/09/23 Python
python isinstance函数用法详解
2020/02/13 Python
使用Python制作一个数据预处理小工具(多种操作一键完成)
2021/02/07 Python
怎样声明接口
2014/09/19 面试题
什么是SQL Server的确定性函数和不确定性函数
2016/08/04 面试题
军训自我鉴定100字
2014/02/13 职场文书
劳资协议书范本
2014/04/23 职场文书
企业诚信承诺书
2014/05/23 职场文书
护士找工作求职信
2014/07/02 职场文书
销售人员求职信
2014/07/22 职场文书
2014个人反腐倡廉思想汇报
2014/09/15 职场文书
四风对照检查材料思想汇报
2014/09/20 职场文书
大学毕业生个人总结
2015/02/28 职场文书
初中开学典礼新闻稿
2015/07/17 职场文书
Java中多线程下载图片并压缩能提高效率吗
2021/07/01 Java/Android
Spring Security中用JWT退出登录时遇到的坑
2021/10/16 Java/Android