前言:

XPath 是一门在 XML 文档中查找信息的语言。XPath 用于在 XML 文档中通过元素和属性进行导航。

XPath 含有超过 100 个内建的函数。这些函数用于字符串值、数值、日期和时间比较、节点和 QName 处理、序列处理、逻辑值等等。

XPath 是 W3C 标准,XPath 于 1999 年 11 月 16 日 成为 W3C 标准。XPath 被设计为供 XSLT、XPointer 以及其他 XML 解析软件使用。

在XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档节点(或称为根节点)。

XML 文档是被作为节点树来对待的。树的根被称为文档节点或者根节点。

一、选取节点

常用的路径表达式:

表达式

描述

实例

nodename

选取nodename节点的所有子节点

xpath(‘//div’)

选取了div节点的所有子节点

/

从根节点选取

xpath(‘/div’)

从根节点上选取div节点

//

选取所有的当前节点,不考虑他们的位置

xpath(‘//div’)

选取所有的div节点

.

选取当前节点

xpath(‘./div’)

选取当前节点下的div节点

..

选取当前节点的父节点

xpath(‘..’)

回到上一个节点

@

选取属性

xpath(’//@calss’)

选取所有的class属性

二、谓词:被嵌在方括号内,用来查找某个特定的节点或包含某个制定的值的节点

表达式

结果

xpath(‘/body/div[1]’)

选取body下的第一个div节点

xpath(‘/body/div[last()]’)

选取body下最后一个div节点

xpath(‘/body/div[last()-1]’)

选取body下倒数第二个div节点

xpath(‘/body/div[positon()<3]’)

选取body下前两个div节点

xpath(‘/body/div[@class]’)

选取body下带有class属性的div节点

xpath(‘/body/div[@class=”main”]’)

选取body下class属性为main的div节点

xpath(‘/body/div[price>35.00]’)

选取body下price元素值大于35的div节点

三、通配符:Xpath通过通配符来选取未知的XML元素

表达式

结果

xpath(’/div/*’)

选取div下的所有子节点

xpath(‘/div[@*]’)

选取所有带属性的div节点

四、取多个路径:使用“ | 运算符可以选取多个路径

表达式

结果

xpath(‘//div|//table’)

选取所有的div和table节点

五、Xpath轴:轴可以定义相对于当前节点的节点集

轴名称

表达式

描述

ancestor

xpath(‘./ancestor::*’)

选取当前节点的所有先辈节点(父、祖父)

ancestor-or-self

xpath(‘./ancestor-or-self::*’)

选取当前节点的所有先辈节点以及节点本身

attribute

xpath(‘./attribute::*’)

选取当前节点的所有属性

child

xpath(‘./child::*’)

返回当前节点的所有子节点

descendant

xpath(‘./descendant::*’)

返回当前节点的所有后代节点(子节点、孙节点)

following

xpath(‘./following::*’)

选取文档中当前节点结束标签后的所有节点

following-sibing

xpath(‘./following-sibing::*’)

选取当前节点之后的兄弟节点

parent

xpath(‘./parent::*’)

选取当前节点的父节点

preceding

xpath(‘./preceding::*’)

选取文档中当前节点开始标签前的所有节点

preceding-sibling

xpath(‘./preceding-sibling::*’)

选取当前节点之前的兄弟节点

self

xpath(‘./self::*’)

选取当前节点

六、功能函数:使用功能函数能够更好的进行模糊搜索

函数

用法

解释

starts-with

xpath(‘//div[starts-with(@id,”ma”)]‘)

选取id值以ma开头的div节点

contains

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

选取id值包含ma的div节点

and

xpath(‘//div[contains(@id,”ma”) and contains(@id,”in”)]‘)

选取id值包含ma和in的div节点

text()

xpath(‘//div[contains(text(),”ma”)]‘)

选取节点文本包含ma的div节点

七、常用函数:

1、精确定位

(1)contains(str1,str2)用来判断str1是否包含str2

例1://*[contains(@class,'c-summaryc-row ')]选择@class值中包含c-summary c-row的节点

例2://div[contains(.//text(),'价格')]选择text()中包含价格的div节点

(2)position()选择当前的第几个节点

例1://*[@class='result'][position()=1]选择@class='result'的第一个节点

例2://*[@class='result'][position()<=2]选择@class='result'的前两个节点

(3)last()选择当前的倒数第几个节点

例1://*[@class='result'][last()]选择@class='result'的最后一个节点

例2://*[@class='result'][last()-1]选择@class='result'的倒数第二个节点

(4)following-sibling 选取当前节点之后的所有同级节点

例1://div[@class='result']/following-sibling::div选择@class='result'的div节点后所有同级div节点找到多个节点时可通过position确定第几个如://div[@class='result']/following-sibling::div[position()=1]

(5)preceding-sibling 选取当前节点之前的所有同级节点

使用方法同following-sibling

2、过滤信息

(1)substring-before(str1,str2)用于返回字符串str1中位于第一个str2之前的部分

例子:substring-before(.//*[@class='c-more_link']/text(),'条')

返回.//*[@class='c-more_link']/text()中第一个'条'前面的部分,如果不存在'条',则返回空值

(2)substring-after(str1,str2)跟substring-before类似,返回字符串str1中位于第一个str2之后的部分

例1:substring-after(.//*[@class='c-more_link']/text(),'条')

返回.//*[@class='c-more_link']/text()中第一个’条’后面的部分,如果不存在'条',则返回空值

例2:substring-after(substring-before(.//*[@class='c-more_link']/text(),'新闻'),'条')

返回.//*[@class='c-more_link']/text()中第一个'新闻'前面与第一个'条'后面之间的部分

(3)normalize-space()

用来将一个字符串的头部和尾部的空白字符删除,如果字符串中间含有多个连续的空白字符,将用一个空格来代替

例子:normalize-space(.//*[contains(@class,'c-summaryc-row ')])

(4)translate(string,str1,str2)

假如string中的字符在str1中有出现,那么替换为str1对应str2的同一位置的字符,假如str2这个位置取不到字符则删除string的该字符

例子:translate('12:30','03','54')结果:'12:45'

3、拼接信息

(1)concat()函数用于串连多个字符串

例子:concat('http://baidu.com',.//*[@class='c-more_link']/@href)

python中xpath用法_Python中的xpath基础使用相关推荐

  1. python的xpath用法_Python爬虫杂记 - Xpath高级用法

    xpath 高级用法 1. 匹配当前节点下的所有: .// . 表示当前 // 表示当前标签下的所有标签 注: 要配合使用 2. 匹配某标签的属性值: /@属性名称 这里以input里的value值为 ...

  2. python的继承用法_python中继承有什么用法?python继承的用法详解

    本篇文章给大家带来的内容是关于python中继承有什么用法?python继承的用法详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 面向对象三大特征 1.封装:根据职责将属性和方法 ...

  3. python if函数用法_python中if条件中的Contains()函数“in”

    我对contains()in的功能做了一些研究,特别是与eq()==进行了比较,发现它可以完成许多任务.我设法回答了其中许多问题(见下文). 除了下面的用法之外,in还有其他有用的用法吗,例如对象?在 ...

  4. python中sorted用法_Python中sorted()方法的用法

    1.先说一下iterable,中文意思是迭代器. Python的帮助文档中对iterable的解释是:iteralbe指的是能够一次返回它的一个成员的对象.iterable主要包括3类: 第一类是所有 ...

  5. python中rjust用法_python中rjust的用法

    英文对话是要加引号的,而且是双引号和单引号的使用方法与中文一样的用法,接下来小编在这里给大家带来,我们一起来看看吧!引号分单引号(singlequotationmarks)和双引号(doublequo ...

  6. python or的用法_python中and和or的用法

    原博文 2013-01-19 13:40 − From <dive into python> python 中的and从左到右计算表达式,若所有值均为真,则返回最后一个值,若存在假,返回第 ...

  7. python isnumeric函数用法_Python中isnumeric()方法的使用简介

    Python中isnumeric()方法的使用简介 更新时间:2015年05月19日 09:35:06 投稿:goldensun 这篇文章主要介绍了Python中isnumeric()方法的使用,is ...

  8. python的继承用法_Python 中的继承之Super用法

    以下Copy自官方文档说明,可点击查看官网源文 翻译内容属于德德自译,有不当之处请指正,勿喷... 翻译括弧中是德德自己理解,通过代码验证的,勿喷... super(type[, object-or- ...

  9. python中的用法_Python中使用@的理解

    Python函数中使用@ 稍提一下的基础 fun 和fun()的区别 以一段代码为例: def fun(): print('fun') return None a = fun() #fun函数并将返回 ...

最新文章

  1. Java IdentityHashMap isEmpty()方法与示例
  2. python 创建一个空向量_Python之Django系列-创建第一个应用-5
  3. excel清空sheet内容 poi_Excel隐藏了一个sheet表,java poi中是可以读出来的,现在我不想读取隐藏的sheet表。...
  4. XML DOM学习笔记(JS)
  5. UVA515 King
  6. Rust :CC编译
  7. java 单击按钮改变背景颜色_java点击按钮换背景颜色?
  8. 7-14 电话聊天狂人
  9. 计算机作业封面,西南交通大学离线作业封面-2016
  10. 分享120个ASP源码,总有一款适合您
  11. 函数式编程之根-拉姆达运算/演算(λ-calculus)
  12. C# 通过反射根据描述特性转换枚举型值
  13. aprilgrid 坐标位置分析
  14. autojs安卓免root实现备份当前文件夹脚本
  15. 【无人机】基于蒙特卡洛算法实现无人机任务分配模型附matlab代码
  16. 申请百度地图开发者AK和基本使用
  17. c语言bnd文件,C语言openssl库DSA签名
  18. 【2021祥云杯】 鸣雏恋
  19. du命令--查看文件、文件夹、磁盘大小
  20. C语言MIPS指令翻译成机器码,计算机指令

热门文章

  1. CMake Error include could not find load file: AwsCFlags 解決辦法
  2. 锐动SDK针对游戏直播提出的解决方案
  3. 2016 年Adobe设计成就奖作品征集
  4. Kettle7 java 远程执行Trans/Job
  5. Metasploit渗透某高校域服务器
  6. WCF 性能基准报告
  7. 《C++编程风格(修订版)》——2.5 动态内存的一致性
  8. 剑指offer66题 -- 输入一个链表,从尾到头打印链表每个节点的值
  9. [Selenium] 基本使用
  10. 《中秋书月》月圆之夜,我和德鲁克