贴几个我学习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. Percona XtraBackup 核心文档

    1. 介绍 1.1 MySQL 备份工具特性对比 Features Percona XtraBackup MySQL Enterprise backup License GPL Proprietary ...

  2. js中的数组去重

    var str=["1","4","5","5","6","1","7 ...

  3. jsp+servlet登录框架模板

    一.建立一个名叫jsp_servlet的工程 二.建立一个AcountBean类和CheckAccount类 1.AcountBean类包含登录名(username)和登录密码(password) p ...

  4. 记录因webpack版本问题导致vue-cli快速搭建的项目运行时报错!

    今日突然在群里见到好几个小伙伴说在创建vue项目后不能跑,会报错. 刚开始还不信,花了几分钟时间自己试了下,还真报错了!如下图 小伙伴的报错,如下图!   百思不得其解,看了运行的日志也找不出原因.于 ...

  5. 你不知道的JSON.stringify和JSON.parse

    json是JavaScript 对象表示法(JavaScript Object Notation),是一种简单的数据格式,类似于XML,其格式为名称/值对,数据用逗号隔开,名称必须用双引号括起来.例如 ...

  6. hackerrank 训练军队

    高阶传送魔法 在神奇的Kasukabe国家,人们努力拥有一个技能.一共有N个类型的技能,并且开始的时候拥有第 i 种技能的人有Ci个 . 这个国家有T个巫师,他们有能力将一个人的技能进行转换.每个巫师 ...

  7. Codeforces Round #404 (Div. 2)(A.水,暴力,B,排序,贪心)

    A. Anton and Polyhedrons time limit per test:2 seconds memory limit per test:256 megabytes input:sta ...

  8. 详解:Python2中的urllib、urllib2与Python3中的urllib以及第三方模块requests

    在python2中,urllib和urllib2都是接受URL请求的相关模块,但是提供了不同的功能.两个最显著的不同如下: 1.urllib2可以接受一个Request类的实例来设置URL请求的hea ...

  9. Xtrabackup实现数据的备份与恢复

    Xtrabackup介绍 Xtrabackup是由percona开源的免费数据库热备份软件,它能对InnoDB数据库和XtraDB存储引擎的数据库非阻塞地备份(对于MyISAM的备份同样需要加表锁): ...

  10. angular1项目打包app及logo和启动图片的设置

    打包思想:ionic和angular混合开发app,那么纯angular1的项目也是可以打包出来. 技术需要:安装一个新的ionic2的项目,环境配置成功,这里打包的配置需要 http://www.c ...