【爬虫实战项目】Python爬取Top100电影榜单数据保存本地(附源码) ...

锦通  金牌会员 | 2022-12-29 11:08:13 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 669|帖子 669|积分 2007

前言

今天给大家介绍的是Python爬取Top100电影榜单数据保存csv文件,在这里给需要的小伙伴们代码,并且给出一点小心得。
首先是爬取之前应该尽可能伪装成浏览器而不被识别出来是爬虫,基本的是加请求头,但是这样的纯文本数据爬取的人会很多,所以我们需要考虑更换代理IP和随机更换请求头的方式来对Top100电影榜单数据进行爬取。
在每次进行爬虫代码的编写之前,我们的第一步也是最重要的一步就是分析我们的网页。
通过分析我们发现在爬取过程中速度比较慢,所以我们还可以通过禁用谷歌浏览器图片、JavaScript等方式提升爬虫爬取速度。

开发工具

Python版本: 3.6
相关模块:
requests模块
time模块
parsel模块
csv模块
环境搭建

安装Python并添加到环境变量,pip安装需要的相关模块即可。
文中完整代码及文件,评论留言获取
思路分析

浏览器中打开我们要爬取的页面
按F12进入开发者工具,查看我们想要的Top100电影榜单数据在哪里
这里我们需要页面数据就可以了

代码实现
  1. for page in range(0, 101, 10):
  2.     time.sleep(2)
  3.     url = 'https://maoyan.com/board/4?offset={}'.format(page)
  4.     headers = {
  5.         'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36',
  6.         'Cookie': '__mta=20345351.1670903159717.1670903413872.1670903436333.5; uuid_n_v=v1; uuid=A8065B807A9811ED82C293D7E110319C9B09821067E1411AB6F4EC82889E1869; _csrf=916b8446658bd722f56f2c092eaae35ea3cd3689ef950542e202b39ddfe7c91e; Hm_lvt_703e94591e87be68cc8da0da7cbd0be2=1670903160; _lxsdk_cuid=1850996db5dc8-07670e36da28-26021151-1fa400-1850996db5d67; _lxsdk=A8065B807A9811ED82C293D7E110319C9B09821067E1411AB6F4EC82889E1869; __mta=213622443.1670903327420.1670903417327.1670903424017.4; Hm_lpvt_703e94591e87be68cc8da0da7cbd0be2=1670903436; _lxsdk_s=1850996db5e-8b2-284-88a%7C%7C18',
  7.         'Host': 'www.maoyan.com',
  8.         'Referer': 'https://www.maoyan.com/films/1200486'
  9.     }
  10.     response = requests.get(url, headers=headers)
  11.     selector = parsel.Selector(response.text)
  12.     li_s = selector.css('.board-wrapper dd')
  13.     for li in li_s:
  14.         name = li.css('.name a::text').get()
  15.         star = li.css('.star::text').get()
  16.         star_string = star.strip()
  17.         releasetime = li.css('.releasetime::text').get()
  18.         data_time = releasetime.strip()
  19.         follow = li.css('.score i::text').getall()
  20.         score = ''.join(follow)
  21.         dit = {
  22.             '电影名字': name,
  23.             '主演': star_string,
  24.             '上映时间': data_time,
  25.             '评分': score,
  26.         }
  27.         csv_write.writerow(dit)
  28.         print(dit)
复制代码
Cookie获取


效果展示


最后

今天的分享到这里就结束了 ,感兴趣的朋友也可以去试试哈
对文章有问题的,或者有其他关于python的问题,可以在评论区留言或者私信我哦
觉得我分享的文章不错的话,可以关注一下我,或者给文章点赞(/≧▽≦)/

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

锦通

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表