编写Python爬虫抓取豆瓣电影TOP100及用户头像的方法


Posted in Python onJanuary 20, 2016

抓取豆瓣电影TOP100
一、分析豆瓣top页面,构建程序结构
1.首先打开网页http://movie.douban.com/top250?start,也就是top页面
然后试着点击到top100的页面,注意带top100的链接依次为

http://movie.douban.com/top250?start=0
http://movie.douban.com/top250?start=25
http://movie.douban.com/top250?start=50
http://movie.douban.com/top250?start=75

2.然后通过查看源码,发现电影名的代码如下:

<span class="title">肖申克的救赎</span>
<span class="title"> / The Shawshank Redemption</span>
如图,因为有一些英文名等描述,通过正则抓取有些干扰,可能还需要后续过滤。

根据以上信息,此程序主要分以下3个步骤:

二、构建url地址池

  • 抓取top100电影名称
  • 依次打印输出

依次写出代码

1.构建url地址池。代码如下:

import urllib2
import re
# ----------确定url地址池------------
pre_url = 'http://movie.douban.com/top250?start='
top_urls = []
# 因为top100,每页25部电影,故为4页,从零开始
for num in range(4):
  top_urls.append(pre_url + str(num * 25))

2.抓取top100电影名称

# ------------抓取top100电影名称----------
top_content = []
top_tag = re.compile(r'<span class="title">(.+?)</span>')
for url in top_urls:
  content = urllib2.urlopen(url).read()
  pre_content = re.findall(top_tag, content)
  # 过滤不符合条件的list,得到最后的top100的list
  for item in pre_content:
    if item.find(' ') == -1:
      top_content.append(item)

3.打印输出

top_num = 1
for item in top_content:
  print 'Top' + str(top_num) + '  ' + item
  top_num += 1

三、整理代码
我还是python新手,还没有太多的pythonic思想,也没有代码优化技巧,只能说是整理。
其次,个人习惯,在简单的代码里面我还是喜欢少用函数,尽量不隐藏代码的逻辑。
以下代码请参考,并欢迎提意见,希望得到大家的意见,谢谢!
整理后的代码如下:

# coding=utf-8
'''
本代码为自动抓取豆瓣top100电影代码
@pre_url url地址前缀,在这里为http://movie.douban.com/top250?start=
@top_urls url地址池
@top_tag 为抓取电影名正则表达式
'''

import urllib2
import re

pre_url = 'http://movie.douban.com/top250?start='
top_urls = []
top_tag = re.compile(r'<span class="title">(.+?)</span>')
top_content = []
top_num = 1

# ----------确定url地址池------------
# 因为top100,每页25部电影,故为4页,从零开始
for num in range(4):
  top_urls.append(pre_url + str(num * 25))


# ------------抓取top100电影名称,并打印输出----------
top_tag = re.compile(r'<span class="title">(.+?)</span>')
for url in top_urls:
  content = urllib2.urlopen(url).read()
  pre_content = re.findall(top_tag, content)
  # 过滤并打印输出
  for item in pre_content:
    if item.find(' ') == -1:
      print 'Top' + str(top_num) + '  ' + item
      top_num += 1

抓取用户头像图片

import urllib.request
import re
import time
 
#获取输入的帖子单页html
def getHtml2(url2):
  html2=urllib.request.urlopen(url2).read().decode('utf-8')
  return html2
 
#抽取图片相关列表,并下载图片
def gettopic(html2):
  reg2=r'http://www.douban.com/group/topic/\d+'
  topiclist=re.findall(reg2,html2)
  x=0
  #限制下载的图片数
  for topicurl in topiclist:
    x+=1
  return topicurl
 
 
#下载图片到本地
def download(topic_page):
  reg3=r'http://img3.douban.com/view/group_topic/large/public/.+\.jpg'
  imglist=re.findall(reg3,topic_page)
  i=1
  download_img=None
  for imgurl in imglist:
#取图片ID为文件名
    img_numlist=re.findall(r'p\d{7}',imgurl)
    for img_num in img_numlist:
       
      download_img=urllib.request.urlretrieve(imgurl,'D:\python\code\girls\%s.jpg'%img_num)
      time.sleep(1) 
      i+=1
      print(imgurl)
  return download_img
 
#调用函数
page_end=int(input('请输入结束时的页码:'))
num_end=page_end*25
num=0
page_num=1
while num<=num_end:
  html2=getHtml2('http://www.douban.com/group/kaopulove/discussion?start=%d'%num)
  topicurl=gettopic(html2)
  topic_page=getHtml2(topicurl)
  download_img=download(topic_page)
  num=page_num*25
  page_num+=1
 
else:
  print('采集完成!')
Python 相关文章推荐
Python中定时任务框架APScheduler的快速入门指南
Jul 06 Python
不可错过的十本Python好书
Jul 06 Python
用matplotlib画等高线图详解
Dec 14 Python
对python中的logger模块全面讲解
Apr 28 Python
简单了解python数组的基本操作
Nov 26 Python
基于梯度爆炸的解决方法:clip gradient
Feb 04 Python
对tensorflow中cifar-10文档的Read操作详解
Feb 10 Python
Django单元测试中Fixtures用法详解
Feb 25 Python
PyQt5中向单元格添加控件的方法示例
Mar 24 Python
Python grequests模块使用场景及代码实例
Aug 10 Python
Python数据分析之pandas函数详解
Apr 21 Python
pytorch 带batch的tensor类型图像显示操作
May 20 Python
以视频爬取实例讲解Python爬虫神器Beautiful Soup用法
Jan 20 #Python
使用Python的urllib和urllib2模块制作爬虫的实例教程
Jan 20 #Python
使用python实现省市三级菜单效果
Jan 20 #Python
八大排序算法的Python实现
Jan 28 #Python
详解C++编程中一元运算符的重载
Jan 19 #Python
Python中使用Queue和Condition进行线程同步的方法
Jan 19 #Python
简单总结Python中序列与字典的相同和不同之处
Jan 19 #Python
You might like
jquery.cookie.js 操作cookie实现记住密码功能的实现代码
2011/04/27 Javascript
Angularjs中如何使用filterFilter函数过滤
2016/02/06 Javascript
Bootstrap每天必学之响应式导航、轮播图
2016/04/25 Javascript
JavaScript-html标题滚动效果的简单实现
2016/09/08 Javascript
JS数字千分位格式化实现方法总结
2016/12/16 Javascript
JS回调函数基本定义与用法实例分析
2017/05/24 Javascript
垃圾回收器的相关知识点总结
2018/05/13 Javascript
解决Vue使用swiper动态加载数据,动态轮播数据显示白屏的问题
2018/09/27 Javascript
微信小程序自定义导航教程(兼容各种手机)
2018/12/12 Javascript
详解如何使用nvm管理Node.js多版本
2019/05/06 Javascript
javascript获取select值的方法完整实例
2019/06/20 Javascript
JS创建自定义对象的六种方法总结
2020/12/15 Javascript
[03:14]2014DOTA2西雅图国际邀请赛 EG战队巡礼
2014/07/07 DOTA
python解析模块(ConfigParser)使用方法
2013/12/10 Python
用Python代码来绘制彭罗斯点阵的教程
2015/04/03 Python
python 显示数组全部元素的方法
2018/04/19 Python
python中datetime模块中strftime/strptime函数的使用
2018/07/03 Python
python实现微信每日一句自动发送给喜欢的人
2019/04/29 Python
在django-xadmin中APScheduler的启动初始化实例
2019/11/15 Python
Pytorch提取模型特征向量保存至csv的例子
2020/01/03 Python
keras model.fit 解决validation_spilt=num 的问题
2020/06/19 Python
Python pathlib模块使用方法及实例解析
2020/10/05 Python
Python读取图像并显示灰度图的实现
2020/12/01 Python
html5 touch事件实现页面上下滑动效果【附代码】
2016/03/10 HTML / CSS
欧洲最大的笔和书写专家:The Pen Shop
2017/03/19 全球购物
加拿大领先的牛仔零售商:Bluenotes
2018/01/22 全球购物
ABOUT YOU匈牙利:500个最受欢迎的时尚品牌
2019/07/19 全球购物
ManoMano英国:欧洲第一家专注于DIY和园艺市场的电商平台
2020/03/12 全球购物
工程采购员岗位职责
2014/03/09 职场文书
护理专科学生自荐书
2014/07/05 职场文书
2014年班级工作总结
2014/11/14 职场文书
2015年社区民政工作总结
2015/04/21 职场文书
初中教师德育工作总结2015
2015/05/12 职场文书
2016大学军训通讯稿
2015/11/25 职场文书
Python标准库之typing的用法(类型标注)
2021/06/02 Python
详解JVM系列之内存模型
2021/06/10 Javascript