爬取ajax动态加载网页——以豆瓣分类电影排行榜

**

网络爬虫练习——爬取ajax动态加载网页

**
如今大多数的网页是通过Ajax加载的,也就是说通过这种方式加载后,就算得到了HTML文档,也不会包含任何数据,而这些数据是通过Ajax加载后才会呈现出来。以豆瓣剧情分类下的电影网页为例,来爬取网页信息,解决动态加载问题。
主要的一部分是查看动态加载的页面的数据,这些数据一般会在Network的 JS或者 XHR 里,查看动态加载的json文件的步骤为:鼠标右击—检查—network—XHR—单击Name中一个XHR—Preview或是鼠标右击—检查—network—单击Name中一个XHR—JS,这样我们通过得到的json文件来分析数据并爬取自己想要的信息。另外我们模拟Ajax请求需要查看页面的源码,具体步骤为鼠标右击—检查—network—单击Name中一个XHR—Headers—Query String Parameters,这样我们就获得了模拟Ajax请求需要的数据
程序代码(只爬取了2页,要想爬取更多页可以通过修改start的值实现)如下:

from urllib.parse import urlencode
import requests
import time
base_url = 'https://movie.douban.com/j/chart/top_list?'
headers = {
    'Host': 'movie.douban.com',
    'Referer': 'https://movie.douban.com/typerank?type_name=%E5%89%A7%E6%83%85&type=11&interval_id=100:90&action=',
    'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.131 Safari/537.36',
    'X-Requested-With': 'XMLHttpRequest'
}
def get_page(start):
    params = {
        'type': '11',
        'interval_id': '100:90',
        'action': '',
        'start': start,
        'limit': 20,
    }
    url = base_url + urlencode(params)
    try:
        response = requests.get(url, headers=headers)
        print('Successful')
        return response.json()
    except requests.ConnectionError as e:
        print('Error', e.args)
def parse_page(html):
    for item in iter(html):
        movie = {}
        movie['rank'] = item['rank']
        movie['title'] = item['title']
        movie['actors']= item['actors']
        movie['regions']= item['regions']
        print(movie)
if __name__ == '__main__':
    for start in range(1, 3):
        html = get_page(start * 20)
        time.sleep(1)
        parse_page(html)




结果如下:

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值