XPath


什么是XPath?

xpath(XML Path Language)是一门在XML和HTML文档中查找信息的语言,可用来在XML和HTML文档中对元素和属性进行遍历。

XPath开发工具

  1. Chrome插件XPath Helper。
  2. Firefox插件Try XPath。

XPath语法

选取节点:

XPath 使用路径表达式来选取 XML 文档中的节点或者节点集。这些路径表达式和我们在常规的电脑文件系统中看到的表达式非常相似。

表达式 描述 示例 结果
nodename 选取此节点的所有子节点 bookstore 选取bookstore下所有的子节点
/ 如果是在最前面,代表从根节点选取。否则选择某节点下的某个节点 /bookstore 选取根元素下所有的bookstore节点
// 从全局节点中选择节点,随便在哪个位置 //book 从全局节点中找到所有的book节点
@ 选取某个节点的属性 //book[@price] 选择所有拥有price属性的book节点
. 当前节点 ./a 选取当前节点下的a标签

谓语:

谓语用来查找某个特定的节点或者包含某个指定的值的节点,被嵌在方括号中。
在下面的表格中,我们列出了带有谓语的一些路径表达式,以及表达式的结果:

路径表达式 描述
/bookstore/book[1] 选取bookstore下的第一个子元素
/bookstore/book[last()] 选取bookstore下的倒数第二个book元素。
bookstore/book[position()<3] 选取bookstore下前面两个子元素。
//book[@price] 选取拥有price属性的book元素
//book[@price=10] 选取所有属性price等于10的book元素

通配符

*表示通配符。

通配符 描述 示例 结果
* 匹配任意节点 /bookstore/* 选取bookstore下的所有子元素。
@* 匹配节点中的任何属性 //book[@*] 选取所有带有属性的book元素。

选取多个路径:

通过在路径表达式中使用“|”运算符,可以选取若干个路径。
示例如下:

//bookstore/book | //book/title
# 选取所有book元素以及book元素下所有的title元素

运算符:

QQ图片20171124194846.png

主要知识点:

xpath语法:

使用方式:

使用//获取整个页面当中的元素,然后写标签名,然后再写谓词进行提取。比如:

//div[@class='abc']

注意:

  1. /和//的区别:/代表只获取直接子节点。//获取子孙节点。一般//用得比较多。当然也要视情况而定。
  2. contains:有时候某个属性中包含了多个值,那么可以使用contains函数。示例代码如下:
    //div[contains(@class,'job_detail')]
    
  3. 谓词中的下标是从1开始的,不是从0开始的。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 传统国文渐行远 故事作文谱新篇 ——全国第五届作文导师团暑期研修第二天精彩呈现 八戒老师主持棒,风趣幽默不会忘;...
    志存高远_开开心阅读 1,441评论 0 0
  • Mac idea Maven项目管理 最近在学习java后台,我使用的是id...
    沉溺IOS阅读 1,310评论 0 0
  • 指针高级应用 一、动态存储 1 分配内存需要用到的函数 2 空指针概念,作用 二、动态分配字符串 1 字符串 2...
    常人阅读 1,211评论 0 1
  • 父亲的身体这两年一直不好,全靠老母亲一人在家照应着。只要有时间,我就会和妹妹经常回家看看。 今天我到菜场买菜...
    夏所珍创作室阅读 3,582评论 3 2
  • 上外这两课,发现有共同点,桃花源是净土,平桥是乐土。 陶渊明向往着和平,自守本心,于是,没有硝烟和战火,众生皆乐的...
    为为道来阅读 5,407评论 0 2

友情链接更多精彩内容