贴几个我学习Xpath的参考

1 基本使用的参考

XPath学习:基本语法(一)

2 较为详细且清晰例子参考,推荐

XPath 详解,总结

3 详细语法参考

Xpath语法格式整理

4 官方参考

XPath 教程

5 XSD (xml Schema Definition)

XML中有几种符号需要使用转义字符,分别是:

实体值字符串 特殊字符

&     &

&lt;       <

&gt;      >

&quot;     "

&apos;     '

说明:

1、实体的引用过到“&”来引用,末尾要加“;”。

2、XML文档中,以上5个特殊字符以实体值字符串形式出现。

自己用过的例子:

1 查找VirtualMachineSnapshotInfo节点下,任意一个VirtualMachineSnapshot节点
VirtualMachineSnapshotInfo//VirtualMachineSnapshot
2 选择多个并列的路径,用“|”
VirtualMachineSnapshotInfo//id|VirtualMachineSnapshotInfo//name
3 选取节点值为某某的节点,并取该节点的父节点的相关值
/A/B[.='AAA']
VirtualMachineSnapshotInfo//VirtualMachineSnapshot[.='snapshot-2309']/parent::node()/id

其中//VirtualMachineSnapshot[.='snapshot-2309']是获取VirtualMachineSnapshot节点为snapshot-2309的节点

//VirtualMachineSnapshot[VirtualMachineSnapshot='snapshot-2309']

4 获取属性的值

<entry id="000000000000002">
<field name="EsxiName">10.200.236.4</field>
</entry>

要获取上面的id值,需用://entry//@id

5 xpath解析带命名空间前缀的xml

样例xml如下,需要解析出Time Machine的值:

<bk:BookStore xmlns:bk="http://www.bookstore.com/book#">
    <bk:Books>
        <bk:Book id=">Time Machine</bk:Book>
    </bk:Books>
</bk:BookStore>        

解析方法:

/*/*[name()='bk:Books']/*[name()='bk:Book' and text()='Time Machine']

6 使用[]过滤当前节点的内容

如下,样例xml中有多个类似如下结构的内容,需要根据给定的name,解析id的值

<result>
  <ax256:addressPools xmlns:ax256="http://dto.bcan.bmc.com/xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="ax256:ContainerAddressPoolDTO">
    <ax256:acquiredFlag>true</ax256:acquiredFlag>
    <ax256:condition xsi:nil="true" />
    <ax256:dnsInfo xsi:type="ax256:DNSInfoDTO">
      <ax256:primaryDnsServer />
      <ax256:primaryDomainSuffixForNic />
      <ax256:reverseDnsServer />
      <ax256:reverseDnsZone />
      <ax256:secondaryDnsServer />
    </ax256:dnsInfo>
    <ax256:endAddress>10.200.160.254</ax256:endAddress>
    <ax256:freeAddressCount></ax256:freeAddressCount>
    <ax256:gatewayAddress>10.200.160.254</ax256:gatewayAddress>
    <ax256:id>CD11D561-DBEA--B51A-5761F977FAFA</ax256:id>
    <ax256:linkId></ax256:linkId>
    <ax256:name>ZH_Vlan160 Address Pool</ax256:name>
    <ax256:natPoolName xsi:nil="true" />
    <ax256:poolAddress>10.200.160.0</ax256:poolAddress>
    <ax256:poolMask>255.255.255.0</ax256:poolMask>
    <ax256:publicFlag>false</ax256:publicFlag>
    <ax256:rangeName xsi:nil="true" />
    <ax256:spaceName>ZH_Vlan160 Address Space</ax256:spaceName>
    <ax256:startAddress>10.200.160.1</ax256:startAddress>
    <ax256:totalAddressCount></ax256:totalAddressCount>
    <ax256:usedAddressCount></ax256:usedAddressCount>
  </ax256:addressPools>
</result>

解析方法:

//*[name()='ax256:addressPools']/.[*="ZH_Vlan160 Address Pool"]/*[name()='ax256:id'])

 7 多个相同的父节点,根据父节点的子节点信息定位某个父节点

<returnval>
      <HostSystem>host-1503</HostSystem>
      <propSet>
        <name>hardware.memorySize</name>
        <val>412243603456</val>
      </propSet>
      <propSet>
        <name>summary.quickStats.overallMemoryUsage</name>
        <val>395960123392</val>
      </propSet>
      <propSet>
        <name>systemResources.config.memoryAllocation.reservation</name>
        <val>392761</val>
      </propSet>
</returnval>

如果我想获取黄色部分的值,则可以如下解析:

//returnval/propSet[./name='hardware.memorySize']/val

Xpath语法学习的更多相关文章

  1. Xpath语法学习记录

    高级参考:https://blog.csdn.net/wudaoshihun/article/details/82226122 举例: 1 <!DOCTYPE html> 2 <ht ...

  2. Python爬虫利器三之Xpath语法与lxml库的用法

    前面我们介绍了 BeautifulSoup 的用法,这个已经是非常强大的库了,不过还有一些比较流行的解析库,例如 lxml,使用的是 Xpath 语法,同样是效率比较高的解析方法.如果大家对 Beau ...

  3. Xpath语法-爬虫(一)

    前言 这一章节主要讲解Xpath的基础语法,学习如何通过Xpath获取网页中我们想要的内容;为我们的后面学习Java网络爬虫基础准备工作. 备注:此章节为基础核心章节,未来会在网络爬虫的数据解析环节经 ...

  4. Xpath语法与lxml库的用法

    BeautifulSoup 已经是非常强大的库了,不过还有一些比较流行的解析库,例如 lxml,使用的是 Xpath 语法,同样是效率比较高的解析方法. 1.安装 pip install lxml 2 ...

  5. xpath语法速查

    xpath的具体学习可以通过w3c查看(链接:http://www.w3school.com.cn/xpath/index.asp) 这里只是将平时用到的几个表格贴出来,以后查询: 这里的xpath我 ...

  6. 网页结构的简介和Xpath语法的入门教程

    相信很多小伙伴已经听说过Xpath,之前小编也写过一篇关于Xpath的文章,感兴趣的小伙伴可以戳这篇文章如何利用Xpath抓取京东网商品信息以及Python网络爬虫四大选择器(正则表达式.BS4.Xp ...

  7. Golang 语法学习笔记

    Golang 语法学习笔记 包.变量和函数. 包 每个 Go 程序都是由包组成的. 程序运行的入口是包 main. 包名与导入路径的最后一个目录一致."math/rand" 包由 ...

  8. Swift高级语法学习总结(转)

    Swift高级语法学习总结 1.函数 1.1 func funcNmae()->(){} 这样就定义了一个函数,它的参数为空,返回值为空,如果有参数和返回值直接写在两个括号里就可以了 1.2 参 ...

  9. Swift基础语法学习总结(转)

    Swift基础语法学习总结 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...

随机推荐

  1. C#中的异步学习

    C#中的异步 C#5.0版本发布有一个"主题那就是异步编程. 我们先创建一个windowForm窗体,实现下面效果,然后我们通过简单的案例对比同步和异步: 首先我们编写一个耗时方法: /// ...

  2. Python进阶内容(二)--- 装饰器

    谈装饰器前,需要明白一件事,Python 中的函数和 Java.C++不太一样,Python 中的函数可以像普通变量一样当做参数传递给另外一个函数,例如: def foo(): print(" ...

  3. 【二分图裸题】poj1325机器调度

    题目大意:有两个机器A和B,A机器有n个模式,B机器有m个模式,两个机器最初在0模式 然后有k个作业,每个作业有三个参数i,a,b i代表作业编号,a和b代表第i作业要么在A机器的a模式下完成[或者] ...

  4. PE文件详解(五)

    在前面几节中经常提到相对虚拟地址RVA,在这篇博客中主要说明这个概念.本来是想接着转载小甲鱼的,但是我自己根据这篇文章和他的视频来学习的时候,发现在RVA与文件的相对偏移地址进行转化的时候,那块我看不 ...

  5. Redis随笔(三)主从搭建

    1.安装redis cd /root/svr/wget http://download.redis.io/releases/redis-3.2.9.tar.gz tar -zxvf redis-3.2 ...

  6. SQLAlchemy表操作和增删改查

    一.SQLAlchemy介绍 SQLAlchemy是一个基于Python实现的ORM框架.该框架建立在 DB API之上,使用关系对象映射进行数据库操作,简言之便是:将类和对象转换成SQL,然后使用数 ...

  7. springboot整合mybaits注解开发

    springboot整合mybaits注解开发时,返回json或者map对象时,如果一个字段的value为空,需要更改springboot的配置文件 mybatis: configuration: c ...

  8. Oracle触发bug(cursor: mutex S),造成数据库服务器CPU接近100%

    问题现象: 项目反馈系统反应非常缓慢,数据库服务器CPU接近100%! INSERT INTO GSPAudit1712(ID,TypeID,CategoryID,DateTime,UserID,Us ...

  9. zookeeper之分布式锁以及分布式计数器(通过curator框架实现)

    有人可能会问zookeeper我知道,但是curator是什么呢? 其实curator是apachede针对zookeeper开发的一个api框架是apache的顶级项目 他与zookeeper原生a ...

  10. Uva 11729 Commando War (简单贪心)

    Uva 11729  Commando War (简单贪心) There is a war and it doesn't look very promising for your country. N ...