C# xpath
XPath最通俗的教程(ZZ)
实例 1
基本的XPath语法类似于在一个文件系统中定位文件,如果路径以斜线 / 开始, 那么该路径就表示到一个元素的绝对路径
|
/AAA |
|
选择根元素AAA |
|
|
|
/AAA/CCC |
|
选择AAA的所有CCC子元素 |
|
|
|
/AAA/DDD/BBB |
|
选择AAA的子元素DDD的所有子元素 |
|
|
实例 2
如果路径以双斜线 // 开头, 则表示选择文档中所有满足双斜线//之后规则的元素(无论层级关系)
|
//BBB |
|
选择所有BBB元素 |
|
|
|
//DDD/BBB |
|
选择所有父元素是DDD的BBB元素 |
|
|
实例 3
星号 * 表示选择所有由星号之前的路径所定位的元素
|
/AAA/CCC/DDD/* |
|
选择所有路径依附于/AAA/CCC/DDD的元素 |
|
|
|
/*/*/*/BBB |
|
选择所有的有3个祖先元素的BBB元素 |
|
|
|
//* |
|
选择所有元素 |
|
|
实例 4
方块号里的表达式可以进一步的指定元素, 其中数字表示元素在选择集里的位置, 而last()函数则表示选择集中的最后一个元素.
|
/AAA/BBB[1] |
|
选择AAA的第一个BBB子元素 |
|
|
|
/AAA/BBB[last()] |
|
选择AAA的最后一个BBB子元素 |
|
|
实例 5
|
//@id |
|
选择所有的id属性 |
|
|
|
//BBB[@id] |
|
选择有id属性的BBB元素 |
|
|
|
//BBB[@name] |
|
选择有name属性的BBB元素 |
|
|
|
//BBB[@*] |
|
选择有任意属性的BBB元素 |
|
|
|
//BBB[not(@*)] |
|
选择没有属性的BBB元素 |
|
|
实例 6
属性的值可以被用来作为选择的准则, normalize-space函数删除了前部和尾部的空格, 并且把连续的空格串替换为一个单一的空格
|
//BBB[@id='b1'] |
|
选择含有属性id且其值为'b1'的BBB元素 |
|
|
|
//BBB[@name='bbb'] |
|
选择含有属性name且其值为'bbb'的BBB元素 |
|
|
|
//BBB[normalize-space(@name)='bbb'] |
|
选择含有属性name且其值(在用normalize-space函数去掉前后空格后)为'bbb'的BBB元素 |
|
|
实例 7
count()函数可以计数所选元素的个数
|
//*[count(BBB)=2] |
|
选择含有2个BBB子元素的元素 |
|
|
|
//*[count(*)=2] |
|
选择含有2个子元素的元素 |
|
|
|
//*[count(*)=3] |
|
选择含有3个子元素的元素 |
|
|
实例 8
name()函数返回元素的名称, start-with()函数在该函数的第一个参数字符串是以第二个参数字符开始的情况返回true, contains()函数当其第一个字符串参数包含有第二个字符串参数时返回true.
|
//*[name()='BBB'] |
|
选择所有名称为BBB的元素(这里等价于//BBB) |
|
|
|
//*[starts-with(name(),'B')] |
|
选择所有名称以"B"起始的元素 |
|
|
|
//*[contains(name(),'C')] |
|
选择所有名称包含"C"的元素 |
|
|
实例 10
多个路径可以用分隔符 | 合并在一起
|
//CCC | //BBB |
|
选择所有的CCC和BBB元素 |
|
|
|
/AAA/EEE | //BBB |
|
选择所有的BBB元素和所有是AAA的子元素的EEE元素 |
|
|
|
/AAA/EEE | //DDD/CCC | /AAA | //BBB |
|
可以合并的路径数目没有限制 |
|
|
实例 11
child轴(axis)包含上下文节点的子元素, 作为默认的轴,可以忽略不写.
|
/AAA |
|
等价于 /child::AAA |
|
|
|
/child::AAA |
|
等价于/AAA |
|
|
|
/AAA/BBB |
|
等价于/child::AAA/child::BBB |
|
|
|
/child::AAA/child::BBB |
|
等价于/AAA/BBB |
|
|
|
/child::AAA/BBB |
|
二者都可以被合并 |
|
|
实例 12
descendant (后代)轴包含上下文节点的后代,一个后代是指子节点或者子节点的子节点等等, 因此descendant轴不会包含属性和命名空间节点.
|
/descendant::* |
|
选择文档根元素的所有后代.即所有的元素被选择 |
|
|
|
/AAA/BBB/descendant::* |
|
选择/AAA/BBB的所有后代元素 |
|
|
|
//CCC/descendant::* |
|
选择在祖先元素中有CCC的所有元素 |
|
|
|
//CCC/descendant::DDD |
|
选择所有以CCC为祖先元素的DDD元素 |
|
|
实例 13
parent轴(axis)包含上下文节点的父节点, 如果有父节点的话
|
//DDD/parent::* |
|
选择DDD元素的所有父节点 |
|
|
实例 14
ancestor轴(axis)包含上下节点的祖先节点, 该祖先节点由其上下文节点的父节点以及父节点的父节点等等诸如此类的节点构成,所以ancestor轴总是包含有根节点,除非上下文节点就是根节点本身.
|
/AAA/BBB/DDD/CCC/EEE/ancestor::* |
|
选择一个绝对路径上的所有节点 |
|
|
|
//FFF/ancestor::* |
|
选择FFF元素的祖先节点 |
|
|
实例 15
following-sibling轴(axis)包含上下文节点之后的所有兄弟节点
|
/AAA/BBB/following-sibling::* |
|
|
|
//CCC/following-sibling::* |
|
|
实例 16
preceding-sibling 轴(axis)包含上下文节点之前的所有兄弟节点
|
/AAA/XXX/preceding-sibling::* |
|
|
|
//CCC/preceding-sibling::* |
|
|
实例 17
following轴(axis)包含同一文档中按文档顺序位于上下文节点之后的所有节点, 除了祖先节点,属性节点和命名空间节点
|
/AAA/XXX/following::* |
|
|
|
//ZZZ/following::* |
|
|
实例 18
preceding轴(axis)包含同一文档中按文档顺序位于上下文节点之前的所有节点, 除了祖先节点,属性节点和命名空间节点
|
/AAA/XXX/preceding::* |
|
|
|
//GGG/preceding::* |
|
|
实例 19
descendant-or-self 轴(axis)包含上下文节点本身和该节点的后代节点
|
/AAA/XXX/descendant-or-self::* |
|
|
|
//CCC/descendant-or-self::* |
|
|
实例 20
ancestor-or-self 轴(axis)包含上下文节点本身和该节点的祖先节点
|
/AAA/XXX/DDD/EEE/ancestor-or-self::* |
|
|
|
//GGG/ancestor-or-self::* |
|
|
实例 21
ancestor, descendant, following, preceding 和self轴(axis)分割了XML文档(忽略属性节点和命名空间节点), 不能交迭, 而一起使用则包含所有节点
|
//GGG/ancestor::* |
|
|
|
//GGG/descendant::* |
|
|
|
//GGG/following::* |
|
|
|
//GGG/preceding::* |
|
|
|
//GGG/self::* |
|
|
|
//GGG/ancestor::* | //GGG/descendant::* | //GGG/following::* | //GGG/preceding::* | //GGG/self::* |
|
|
实例 22
div运算符做浮点除法运算, mod运算符做求余运算, floor函数返回不大于参数的最大整数(趋近于正无穷), ceiling返回不小于参数的最小整数(趋近于负无穷)
|
//BBB[position() mod 2 = 0 ] |
|
选择偶数位置的BBB元素 |
|
|
|
//BBB[ position() = floor(last() div 2 + 0.5) or position() = ceiling(last() div 2 + 0.5) ] |
|
选择中间的BBB元素 |
|
|
|
//CCC[ position() = floor(last() div 2 + 0.5) or position() = ceiling(last() div 2 + 0.5) ] |
|
选择中间的CCC元素 |
|
|
C# xpath的更多相关文章
- xpath提取多个标签下的text
title: xpath提取多个标签下的text author: 青南 date: 2015-01-17 16:01:07 categories: [Python] tags: [xpath,Pyth ...
- C#+HtmlAgilityPack+XPath带你采集数据(以采集天气数据为例子)
第一次接触HtmlAgilityPack是在5年前,一些意外,让我从技术部门临时调到销售部门,负责建立一些流程和寻找潜在客户,最后在阿里巴巴找到了很多客户信息,非常全面,刚开始是手动复制到Excel, ...
- 在Java中使用xpath对xml解析
xpath是一门在xml文档中查找信息的语言.xpath用于在XML文档中通过元素和属性进行导航.它的返回值可能是节点,节点集合,文本,以及节点和文本的混合等.在学习本文档之前应该对XML的节点,元素 ...
- XPath 学习二: 语法
XPath 使用路径表达式来选取 XML 文档中的节点或节点集.节点是通过沿着路径 (path) 或者步 (steps) 来选取的. 下面列出了最有用的路径表达式: 表达式 描述 nodename 选 ...
- xpath 学习一: 节点
xpath 中,有七种类型的节点: 元素.属性.文本.命名空间.处理指令.注释.以及根节点 树的根成为文档节点或者根节点. 节点关系: Parent, Children, sibling(同胞), A ...
- Python爬虫利器三之Xpath语法与lxml库的用法
前面我们介绍了 BeautifulSoup 的用法,这个已经是非常强大的库了,不过还有一些比较流行的解析库,例如 lxml,使用的是 Xpath 语法,同样是效率比较高的解析方法.如果大家对 Beau ...
- 使用python+xpath 获取https://pypi.python.org/pypi/lxml/2.3/的下载链接
使用python+xpath 获取https://pypi.python.org/pypi/lxml/2.3/的下载链接: 使用requests获取html后,分析html中的标签发现所需要的链接在& ...
- 关于robotframework,app,appium的xpath定位问题及常用方法
关于类似的帖子好像很多,但是没有找到具体能帮我解决问题的办法.还是自己深究了好久才基本知道app上面的xpath定位和web上的不同点: 先放一个图: A,先说说不用xpath的场景,一般是用于存在i ...
- Selenium Xpath Tutorials - Identifying xpath for element with examples to use in selenium
Xpath in selenium is close to must required. XPath is element locator and you need to provide xpath ...
- xpath定位中starts-with、contains和text()的用法
starts-with 顾名思义,匹配一个属性开始位置的关键字 contains 匹配一个属性值中包含的字符串 text() 匹配的是显示文本信息,此处也可以用来做定位用 eg //input[sta ...
随机推荐
- Rank() 、DENSE_RANK()、NTILE(n)的用法-转
Rank() over()/DENSE_RANK() over()的用法 1.Rank() over()/DENSE_RANK() over() 这两个函数与ROW_NUMBER()函数类似,因为 ...
- [原创]导出CSV文件,特殊字符处理。
CSV文件格式 1.CSV文件默认以英文逗号(,)做为列分隔符,换行符(\n)作为行分隔符.2.CSV默认认为由""括起来的内容是一个栏位,这时不管栏位内容里有除"之外字 ...
- mydumper 快速高效备份mysql,按照表生成备份文件,快速恢复
Mydumper是一个针对MySQL和Drizzle的高性能多线程备份和恢复工具.开发人员主要来自MySQL,Facebook,SkySQL公司.目前已经在一些线上使用了Mydumper. Mydum ...
- C#/ASP.NET MVC微信公众号接口开发之从零开发(四) 微信自定义菜单(附源码)
C#/ASP.NET MVC微信接口开发文章目录: 1.C#/ASP.NET MVC微信公众号接口开发之从零开发(一) 接入微信公众平台 2.C#/ASP.NET MVC微信公众号接口开发之从零开发( ...
- CentOS6.5 下安装 texlive2015 并设置 ctex 中文套装
0 卸载旧版本的 texlive 0.1 卸载 texlive2007 如果系统没有安装过texlive,则跳过第0步. 可以在终端中使用如下命令查询本机已经安装的tex和latex版本: [She@ ...
- cacti监控juniper路由器
之前也没有写过博客,但是最近一直在做监控.从网上查找很多资料都还是感觉差一点.所以自己添加一份我在cacti监控路由器的步骤. 环境,ubuntu14.04,apt-get install cacti ...
- nginx 模块讲解
1. 通用配置选项: --prefix=<path> 指定Nginx的安装路径,所有其他的路径都要依赖于该选项 --sbin-path=<path> ...
- Bootstrap <基础二十三>页面标题(Page Header)
页面标题(Page Header)是个不错的功能,它会在网页标题四周添加适当的间距.当一个网页中有多个标题且每个标题之间需要添加一定的间距时,页面标题这个功能就显得特别有用.如需使用页面标题(Page ...
- 《Pro Express.js》学习笔记——app.params中间件
app.param中间件用于对URL中的参数进行获取.加工.输出,提供公有逻辑,以达到代码重构的目的. 以下示例采取三个步骤对代码进行重构,app.param中间件的作用非常明显: 不使用中间件 使用 ...
- Buffer、Channel示例
a.txt 孔雀向西飞,今朝更好看.孔雀向西飞,今朝更好看.孔雀向西飞,今朝更好看.孔雀向西飞,今朝更好看. 示例一. package com.test; import java.io.FileI ...