文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

requests-html爬虫利器介绍

2023-01-30 23:33

关注

爬虫用的最多的包无非就是requests, urllib,然后再利用pyquery或者bs4,xpath再去整理提取需要的目标数据。

在requests-html里面只需要一步就可以完成而且可以直接进行js渲染.

requests的作者Kenneth Reitz 开发的requests_html是基于现有的框架 PyQuery、Requests、lxml、beautifulsoup4等库进行了二次封装,这里是github地址:https://github.com/kennethreitz/requests-html


安装

pip3 install requests-html


基础用法:

from requests_html import HTMLSession

session = HTMLSession()
taobao = session.get('https://www.taobao.com/')
# 获取状态码
status_code = taobao.status_code
# 获取cookies信息
cookies = taobao.cookies
# 获取网页内的所有链接,返回set类型
link_list = taobao.html.links
# 获取页面上所欲偶的链接,以绝对路径的方式,返回set类型
ab_link_list = taobao.html.absolute_links


获取元素,request-html支持CSS选择器和XPATH两种语法来选取HTML元素。

requests-html  CSS选择器语法它需要使用html的find函数,html.find,

css选择器语法:http://www.w3school.com.cn/cssref/css_selectors.asp

示例代码:

from requests_html import HTMLSession

session = HTMLSession()
r = session.get('https://www.py3study.com/')
title_list = r.html.find('.index_arc_item h4 a')
for i in title_list:
    print(i.text)

返回信息:

image.png


通过css选择器选取一个Element对象

from requests_html import HTMLSession

session = HTMLSession()
r = session.get('https://www.python.org/')
# 通过css选择器选取一个Element对象
node = r.html.find('#about', first=True)
# 获取一个Element对象内的文本信息
node_text = node.text

# 获取一个Element对象的所有attributes
node_attes = node.attrs

# 渲染出一个Element对象的HTML内容
node_html = node.html

# 获取Element对象内的特定子ELement对象,返回列表
node_list = node.find('a')



requests-html  XPATH语法,需要html的xpath函数,html.xpath

xpath选择器语法:http://www.w3school.com.cn/xpath/index.asp

示例代码:

from requests_html import HTMLSession

session = HTMLSession()
r = session.get('https://www.py3study.com/')
# 找到所有文章
title_list = r.html.xpath("//h4[@class='title']/a/text()")

返回信息:

image.png



重点!!!requests-html支持JavaScript

访问猫眼实时票房页面:https://piaofang.maoyan.com/dashboard

示例代码:当你第一次调用render()方法时,代码将会自动下载Chromium,并保存在你的家目录下(如:~/.pyppeteer/),只会下载这一次(需要梯子才能下载)

from requests_html import HTMLSession

session = HTMLSession()
r = session.get('https://piaofang.maoyan.com/dashboard')
r.html.render()
print(r.text)

返回信息:

image.png


render函数还有一些参数,介绍一下(这些参数有的还有默认值,直接看源代码方法参数列表即可): 

- retries: 加载页面失败的次数 

- script: 页面上需要执行的JS脚本(可选) 

- wait: 加载页面钱的等待时间(秒),防止超时(可选) 

- scrolldown: 页面向下滚动的次数 

- sleep: 在页面初次渲染之后的等待时间 

- reload: 如果为假,那么页面不会从浏览器中加载,而是从内存中加载 

- keep_page: 如果为真,允许你用r.html.page访问页面


比如说简书的用户页面上用户的文章列表就是一个异步加载的例子,初始只显示最近几篇文章,如果想爬取所有文章,就需要使用scrolldown配合sleep参数模拟下滑页面,促使JS代码加载所有文章

还有正在开发的智能分页系统这里还没有完善不过多介绍



requests-html自定义用户代理

有些网站会使用UA来识别客户端类型,有时候需要伪造UA来实现某些操作

from requests_html import HTMLSession
from pprint import pprint
import json
session = HTMLSession()
r = session.get('http://httpbin.org/get')
pprint(json.loads(r.html.html))

返回信息:

image.png


requests-html更换user-agent,访问

from requests_html import HTMLSession
from pprint import pprint
import json
session = HTMLSession()
ua = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:62.0) Gecko/20100101 Firefox/62.0'
r = session.get('http://httpbin.org/get', headers={'user-agent': ua})
pprint(json.loads(r.html.html))

返回信息,可以看到user-agent已经变了

image.png



requests-html模拟表单登陆

HTMLSession带了一整套的HTTP方法,包括get、post、delete等,对应HTTP中各个方法.

from requests_html import HTMLSession
from pprint import pprint
import json
session = HTMLSession()
r = session.post('http://httpbin.org/post', data={'username': 'root', 'passwd': 'root'})
pprint(json.loads(r.html.html))

返回信息:

image.png


requests-html更多使用方法查看:https://cncert.github.io/requests-html-doc-cn/#/?id=user_agent


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯