zoukankan
html css js c++ java
XML篇查询语言XPath
XPath
• XPath(XML 路径语言)是用来查询和定位XML文档里的元素以及文本的一种通用查询方法。
• 许多人将XPath看作Internet的SQL语言。
• XPath语法使用称为表达式的模式。初始化时结果集中没有任何东西,利用XPath表达式使得出现在结果集里的节点形成特定的层次结构并符合一定的条件。
• XPath上下文:是我们将要查询文档的文档树中一个特定的节点。可以认为是查询的一个起始点。
XPath表达式
• 由位置步组成。它由一个轴、一个节点测试和可选择的一系列谓词构成。通过使用反斜杠连接多个位置步形成位置路径,产生一组节点作为结果。
• /Books/book/title:要求元素Books的子元素book的所有子元素title。
• /Books/book[@Price
<
21
.99]/title:返回Books根元素下book子元素中,所有Price属性值小于21.99的book的所有title子元素
• 位置步:表达式中由反斜杠分开的每个部分被称为一个位置步。
• 轴:是与上下文节点相对的文档的一部分,它定义了一组与当前节点有特定层次关系的节点。
• 节点测试:可以用来指示位置路径中一组合法节点的任何表达式。节点测试通过名字或类型筛选初始结果集。
– child::text():返回所有文本子节点。
• 谓词:true或false的一个表达式。
轴
• 轴心包括:self、child、parent、descendent、ancestor、attribute、namespace、following、preceding
• child::Customer:返回当前节点子元素中的所有Customer元素
• descendent::OrderItem:返回节点名为OrderItem“的所有后代
XPath表达式示例
• ./Order将找到当前上下文中名为Order的所有元素
• /Order将找到文档树中根下所有名为Order的元素
• //Order将在文档树的任何地方找到所有名为Order的元素,不管深度或层次结构
• child::book[attribute::publisher
=‘张三’]
• child::book[@publisher
=‘张三’]
• descendent::book[count(child::chapter)
>
5]:用
count函数检索所有chapter大于5的后代book节点
• child::book[start-with(attribute::publisher,’张’)]:使
用start-with函数检索所有publisher属性以’张’开头
的book子节点.
XPath缩略语法
• //代表后代轴
• @代表属性轴
• .代表自己
• ..代表父节点
所需查询的XML
<?
xml version
=
"
1.0
"
encoding
=
"
utf-8
"
?>
<
Orders
>
<
Customer Name
=
'
Albert
'
>
<
Order Quantity
=
"
12
"
>
Roast Duck
</
Order
>
<
Order Quantity
=
"
5
"
>
Red Wine
</
Order
>
</
Customer
>
<
Customer Name
=
'
John
'
>
<
Order Quantity
=
"
3
"
>
French Fries
</
Order
>
<
Order Quantity
=
"
4
"
>
Coffee
</
Order
>
</
Customer
>
<
Customer Name
=
'
Stephen
'
>
<
Order Quantity
=
"
5
"
>
Milk
</
Order
>
</
Customer
>
<
Customer Name
=
'
Alice
'
>
<
Order Quantity
=
"
18
"
>
Frozen Pizza
</
Order
>
<
Order Quantity
=
"
3
"
>
Potato Chips
</
Order
>
</
Customer
>
</
Orders
>
程序:
protected
void
Page_Load(
object
sender, EventArgs e)
{
XmlDocument xmlDocument
=
new
XmlDocument();
//
Load Xml
xmlDocument.Load(Server.MapPath(
"
Test.xml
"
));
//
查询Name为A开头的节点
XmlNodeList xmlNodeList
=
xmlDocument.DocumentElement.SelectNodes(
"
//Customer[starts-with(@Name,'A')]/Order
"
);
//
总共找到几个Node
Response.Write(
"
Found:
"
+
xmlNodeList.Count.ToString()
+
"
node<br>
"
);
foreach
(XmlNode xmlNode
in
xmlNodeList)
{
//
取得Name节点的Value
string
parentNodeAttribute
=
xmlNode.ParentNode.Attributes.GetNamedItem(
"
Name
"
).Value;
//
取得Quantity的Value
string
elementAttribute
=
xmlNode.Attributes.GetNamedItem(
"
Quantity
"
).Value;
//
显示
Response.Write(
"
Customer Name:
"
+
parentNodeAttribute
+
"
Ordered Quantity:
"
+
elementAttribute
+
""
+
xmlNode.InnerText
+
"
<br>
"
);
}
}
查看全文
相关阅读:
进程的挂起及恢复
移植 iconv
产生不重复随机数
Javascript数据验证类
简单设置让EasyUI显示中文,日期选择框格式为yyyyMMdd格式
NPOI开源组件(操作Execl)创建Workbook和Sheet,创建单元格,设置行列样式等
PL/SQL中流程控制语句 和Oracle临时表
c#字符串中包含的运算符按正常计算 例如按四则运算等,类似公式计算,很好很强大
判断一个数组中的值是否包含在另一个数组中
利用NPOI开源的读写Excel、WORD等微软OLE2组件读写execl,控制样式或单元格
原文地址:https://www.cnblogs.com/RuiLei/p/647603.html
最新文章
Css实现tab标签效果(二)内容为动态的div
Jquery调用Asp.Net WebService和form 提交到Handler方式
Css实现tab标签效果(一)内容为静态的div
纵向菜单
给数据库里的表设置联合主键
部署IIS注意事项
Excel文件上传并导入Sqlserver数据库
发送邮件
javascript最最常用的55个经典技巧
sqlserver数据库导出到Excel文件
热门文章
优秀程序员应该避免的10个陷阱
eclipse中同步代码PULL报错checkout conflict with files的解决方法
pom.xml配置引用项目时不生效
boost 系列 2:boost 编译
Compile libtorrent
vs2008 编译libtorrent
C Data types
boost 系列 1:boost 直接使用
【排序】简单选择排序
linux下/proc/stat 计算CPU利用率
Copyright © 2011-2022 走看看