python如何使用xpath?实例及常用函数

2022-10-1821:10:40编程语言入门到精通Comments991 views字数 1049阅读模式

一. python使用xpath

使用时先安装 lxml 包文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

pip install lxml

二. xpath简介

XPath,全称 XML Path Language,即 XML 路径语言,它是一门在 XML 文档中查找信息的语言。XPath 可用来在 XML 文档中对元素和属性进行遍历。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

  1. XPath 使用路径表达式在 XML 文档中进行导航
  2. XPath 包含一个标准函数库
  3. XPath 是 XSLT 中的主要元素
  4. XPath 是一个 W3C 标准

三. xpath语法

在 XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档(根)节点。XML 文档是被作为节点树来对待的。树的根被称为文档节点或者根节点。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

下面列出了最常用的表达式文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

python如何使用xpath?实例及常用函数
image.png

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

通配符:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

python如何使用xpath?实例及常用函数
image.png

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

四. 实例

xml文件:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

<?xml version="1.0" encoding="ISO-8859-1"?>
<bookstore>
<book>
  <title lang="eng">Harry Potter</title>
  <price>29.99</price>
</book>

<book>
  <title lang="eng">Learning XML</title>
  <price>39.95</price>
</book>
</bookstore>

简单的查找文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

python如何使用xpath?实例及常用函数
image.png

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

谓语 & 查找特定的节点文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

python如何使用xpath?实例及常用函数
image.png

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

通配符举例文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

python如何使用xpath?实例及常用函数
image.png

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

选取若干路径文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

python如何使用xpath?实例及常用函数
image.png

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html

五. 常用函数

5.1 starts-with() 获取以xxx开头的元素

xpath(‘//div[stars-with(@class,”test”)]’)

7.2 ends_with() 以xxx结尾

xpath("//input[ends-with(@id,'fuck')]")

7.3 contains() 获取包含xxx的元素

xpath(‘//div[contains(@id,”test”)]’)

7.4 and 并且 同时

xpath("//input[@type='submit' and @name='fuck']")

7.5 or 或者

xpath("//input[@type='submit' or @name='fuck']")

7.6 not 非

xpath("//input[@type='submit' and not(contains(@name,'fuck'))]")

7.7 text()

xpath(‘//div[contains(text(),”test”)]’)
xpath(‘//div[@id=”“test]/text()’)
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/28370.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/ymba/28370.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定