pyQuery:一个使用jquery语法超简单的html解析库

在使用python爬取网页时,一个好的html解析库将事半功倍,通常用的比较多的有 Beautiful Soup

Beautiful Soup提供一些简单的函数用来处理导航、搜索、修改分析树等功能。 它是一个工具箱,通过解析文档为用户提供需要抓取的数据,因为简单,所以不需要多少代码就可以写出一个完整的应用程序。

功能强大、性能不错,而且对损坏的html也能有较高的容忍度。

不过今天要说的是另一个库pyQuery :这是是一个风格类似于jQuery的html解析库,就像名字所暗示的,在获取html元素和提取数据时,风格几乎和jQuery一模一样。

比如,要获取所有a元素,pq('a') pq(".link a"), 如果熟悉jquery的话,用起来得心应手超级简单,相比beautiful 更简单,支持链式调用,代码量更少。

不同点 BeautifulSoup PyQuery
语法和API 简单直观 jQuery风格
CSS 选择器/XPath CSS选择器为主 CSS选择器和XPath
社区 活跃庞大的社区 较小

安装pyQuery

就和安装其他pip库一样,pip install pyquery,一行代码完成安装

代码中导入即可使用 import pyquery

装载 html 创建pyquery对象

通过requests或其他http请求库获取到html文本,构建一个pyquery对象,即可检索提取其中的元素和数据。

doc=pyquery("html文本")

当然也可以直接传入url地址,由pyquery抓取网页

doc=pyquery("http:xxxx")

或者传递一个本地html文件路径

doc=pyquery(filename="xxx/xx.html")

获取元素:css选择器语法

doc是一个pyquery对象,可使用几乎绝大多数jquery选择器语法来获取某个或某些元素

scss 复制代码
doc("a")   
doc(".link")   
doc("#user .link")   
doc("[data-name]") 
doc('.product[attributeName^="product"]')
doc(".mybook > .column")

获取元素:使用find()方法

就像jquery中 find(".link"),在pyquery中,也可以使用find方法寻找元素,包括链式调用

doc(".product_list").find(".meta-info")

获取和设置元素信息

获取到元素后,可以调用对应方法设置或获取需要的信息

  • text(): 获取或设置元素文本

比如获取id为user的a标签的文本内容,使用jquery怎么获取,pyquery也是怎么获取

doc('#a').text()

  • attr():获取或设置元素属性

获取这个元素的href属性 doc('#a').attr('href')

一如 jquery,text() 用于获取或设置元素的文本内容,attr()用于获取或设置属性

  • html(): 获取或设置元素的html内容

doc('#a').html("<strong>hello</strong>")

  • addClass()/removeClass: 给元素添加或异常类

doc("#a").addClass("name")

  • css(): 获取或设置元素的css doc("#a").css("font-size", "15px")

  • remove(): 移除不需要的元素

doc("head").remove() 直接删掉用不到的元素,更方便提取数据

还有哪些方法? 通常常用的jquery操作元素的方法,在pyquery里可直接使用。

hide()/width()/height()/eq()/next()/prev()/children()/append()/prepend()/after()/before()/val()

具体可查看官方文档 pythonhosted.org/pyquery/api...

获取多个元素

就像 $("a") 获取文档中所有的a标签一样,doc("a") 也是获取到所有a元素,调用它的 items() 方法,返回所有这些a元素的list,

scss 复制代码
for it in doc("a").items():
    print(it.attr('href'))
    

items() 中的每个元素都是一个pyquery对象,可以继续使用选择器获取子元素或直接获取属性。

注意事项

默认情况下,pyquery 使用 lxml的xml 解析器,如果失败,则继续尝试 lxml.html 中的 html 解析器。 不过可以显式选择要使用的解析器:

css 复制代码
pq('<html><body><p>toto</p></body></html>', parser='xml')

pq('<html><body><p>toto</p></body></html>', parser='html')

pq('<html><body><p>toto</p></body></html>', parser='html_fragments')

为什么要选pyquery呢?

简单、灵活、链式调用,写更少的代码,是我使用它的主要原因。

  • 简洁而熟悉的语法: 如果已经熟悉了 jQuery,那么使用 PyQuery 如鱼得水。
  • 高效强大的解析功能: 底层使用 lxml 库,这个库以解析 HTML 和 XML 文档的速度和效率著称
  • 灵活的数据提取: 可以灵活地使用 CSS 选择器、XPath 表达式甚至正则表达式提取数据。

官方文档

pythonhosted.org/pyquery/ind...

相关推荐
孤狼warrior12 分钟前
公司信息建设库数据 使用调用堆栈的JS逆向爬虫
javascript·爬虫
MediaTea30 分钟前
Python 第三方库:cv2(OpenCV 图像处理与计算机视觉库)
开发语言·图像处理·python·opencv·计算机视觉
江塘1 小时前
机器学习-决策树多种生成方法讲解及实战代码讲解(C++/Python实现)
c++·python·决策树·机器学习
多彩电脑1 小时前
死循环逻辑检测
数据结构·python·算法·动态规划
YongCheng_Liang1 小时前
Python 基础核心模块全解析:从入门到实践的知识框架
python
RanMatrix1 小时前
python-logging模块
python
e***74951 小时前
Redis——使用 python 操作 redis 之从 hmse 迁移到 hset
数据库·redis·python
Ace_31750887762 小时前
京东商品详情接口终极突破:从多接口联动解析到数据全息重构
python·重构
汗流浃背了吧,老弟!2 小时前
Langchian检索YouTube视频字幕
python·音视频
励志前端小黑哥2 小时前
uv包管理器--python也有自己的pnpm了
开发语言·python·uv