XML的xPath格式
XML的xPath格式(C#)
xPath是XML提供的一种格式,用来查询XML的节点。
<?xml version="1.0" encoding="ISO-8859-1"?> <bookstore> <book> <title name="wu" lang="eng">Harry Potter</title> <price>29.99</price> </book> <book> <title lang="eng">Learning XML</title> <price>39.95</price> </book> </bookstore>
下面讲解的xPath语法都是根据上面的XML来的。
"bookstore"
从当前节点的子节点中选择名为bookstore的节点。
"/bookstore"
从根节点的子节点中选择名为bookstore的节点。
"//bookstore"
从XML的任意位置选择名为bookstore的节点。重点突出这个任意位置,它不受当前节点的影响,也就是说假如当前节点是在第 100 层(有点夸张),也可以选择第一层的名称为 bookstore的节点。
"."
选择当前节点
".."
选择当前节点的父节点,也就是上一层的节点。
"//title[@lang]"
选择带有lang属性,并且名为title的节点
"//title[@lang='eng']"
选择带有lang属性,并且lang属性值为eng,名为title的节点
"//book[price>30]"
选择名为book的节点,选择的节点必须有一个名为price的子节点,并且子节点的值要满足>30的条件
"//book[2]"
选择名为book的第二个节点,注意序号是从1开始,不是0
"//book[last()]"
选择左后一个名为book的节点
"//book[position()<=2]"
选择前2个名为book的节点
"//title//@lang"
选择名为title的节点的属性值,注意这里得到是属性,而不是节点
"//price[text()]"
选择名为price的节点的内容
"//title[@*]"
选择名为title的节点的所有属性值
"//bookstore/*/price"
*表示任意名字
"//title|//price"
选择名为title或者名为price的节点
"//book[contains(price, '99')]"
选择名为book的节点,选中的节点含有名为price的子节点,并且子节点值含有99字符
"//title[contains(@lang, 'en')]"
选择名为title,选中的节点含有名为lang的属性,并且属性值含有dn字符
"//title[@name='wu' and @lang='eng']"
选择名为title的节点,选中的节点含有name和lang属性,并且属性值分别为wu和eng
如果XML带有名字空间,例如:
<?xml version="1.0" encoding="ISO-8859-1"?> <bookstore xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> <book> <title name="wu" lang="eng">Harry Potter</title> <price>29.99</price> </book> <book> <title lang="eng">Learning XML</title> <price>39.95</price> </book> </bookstore>
这种情况要使用xPath就必须带有名字空间,否则查询结构都为0。
举个例子,假设我已将名字空间http://schemas.microsoft.com/developer/msbuild/2003声明为ns,要使用之前说明过的
"//title[contains(@lang, 'en')]"
就必须写成这样的形式
"//ns:title[contains(@lang, 'en')]"
XML的xPath格式的更多相关文章
- xml的xPath解析规则
一,为什么要用xpath技术 问题:当使用dom4j查询比较深的层次结构的节点(标签,属性,文本),比较麻烦!!! 二,xpath的规则 2.1,/根元素的案例 /AAA 选择根元素AAA ...
- 【.net 深呼吸】聊聊WCF服务返回XML或JSON格式数据
有时候,为了让数据可以“跨国经营”,尤其是HTTP Web有关的东东,会将数据内容以 XML 或 JSON 的格式返回,这样一来,不管客户端平台是四大文明古国,还是处于蒙昧时代的原始部落,都可以使用这 ...
- Parse xml/json[xpath/jpath]
import groovy.util.XmlSlurper import groovy.util.XmlParser import com.eviware.soapui.support.GroovyU ...
- php返回json,xml,JSONP等格式的数据
php返回json,xml,JSONP等格式的数据 返回json数据: header('Content-Type:application/json; charset=utf-8'); $arr = a ...
- Ajax中XML和JSON格式的优劣比较
刚做完一个小的使用Ajax的项目.整个小项目使用JavaScript做客户端,使用PHP做服务器端.利用xmlHttpRequest组件作为交互工具,利用XML作为数据传输的格式.做完后基本做一个简单 ...
- java XML转JSON格式
标签: XML转Json json 2014-05-20 20:55 6568人阅读 评论(6) 收藏 举报 分类: [J2SE基础](20) 代码如下所示,从这个例子中发现了代码库的重要性,如果 ...
- 通过notepad++将混乱的xml配置的格式进行美化
需求描述: 最近在进行hbase配置文件的修改之后,发现xml文件的格式很不美观, 然后,在网上找了些方法,实测,通过notepad++的xml tools插件就可 达到美化效果. 操作过程: 1.以 ...
- .net WebAPI返回xml、json格式
WebAPI返回xml.json格式简单示例 using System.Net.Http.Formatting; public class TestController : ApiController ...
- C#操作Xml:XPath语法 在C#中使用XPath示例
XPath可以快速定位到Xml中的节点或者属性.XPath语法很简单,但是强大够用,它也是使用xslt的基础知识. 示例Xml: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ...
随机推荐
- 【转】简单十步让你全面理解SQL
简单十步让你全面理解SQL 很多程序员认为SQL是一头难以驯服的野兽.它是为数不多的声明性语言之一,也因为这样,其展示了完全不同于其他的表现形式.命令式语言. 面向对象语言甚至函数式编程语言(虽然有些 ...
- 程序员快围观!2016年最受欢迎中国开源软件TOP 20
[PConline 资讯]开源软件对程序员来说是一个经常接触的软件,作为一个经常接触的软件,当然想知道自己用的软件受欢迎程度,基于此,开源中国在近日公布"2016年度最受欢迎中国开源软件评选 ...
- Android 动画的分类
分为三类: View Animation (补间动画 Tween动画) Drawable Animation(帧动画 Frame动画) Property Animation(android 3.0引入 ...
- windows下npm scripts不能执行的问题
最近在学webpack为了方便把运行脚本写入package.json文件中,如下: "scripts": { "start": "webpack-de ...
- 解决 jQuery.UI.Resizable aspectRatio在init后无法重新设置
一.背景 在jQuery1.9.x版本之前,存在aspectRatio在Resizable方法init之后,无法再次修改aspectRatio的boolean值. 二.解决方案 // 用于fix j ...
- centos6.4、6.5、7.0环境下载及安装
centos6.4.6.5.7.0下载地址: http://www.cnblogs.com/zhwl/p/3657958.html或 http://www.linuxdown.net/CentOS/2 ...
- GOPS2017全球运维大会深圳站 出席嘉宾盘点!
去年,GOPS全球运维大会在深圳出发,当时门票提前几周收盘,2017年,承载着运维人的期望,GOPS全球运维大会再次来到了深圳.第六届GOPS2017全球运维大会深圳站(本次)将于2017年4月21日 ...
- php学习笔记——日期和时间
一.time() 来取得服务器当前时间的时间戳 UNIX 时间戳(timestamp)是 PHP 中关于时间日期一个很重要的概念,它表示从 1970年1月1日 00:00:00 到当前时间的秒数之和. ...
- oracle建表的时候同时创建主键,外键,注释,约束,索引
--主键create table emp (id number constraint id_pr primary key ,name1 varchar(8));create table emp9 (i ...
- SQLServer批量更新
两种写法,暂未知道区别 1. UPDATE aSET a.resblockid = ( SELECT b.resblockId FROM yyy.dbo.yyy b WHERE a.unitId = ...