java中的xpath,读取xml文档。

1,入门html

XPath即为XML路径语言(XML Path Language),它是一种用来肯定XML文档中某部分位置的语言。java

XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。起初 XPath 的提出的初衷是将其做为一个通用的、node

介于XPointer与XSL间的语法模型。可是 XPath 很快的被开发者采用来看成小型查询语言。express

2,了解数据结构

若是要定位xml文档中的某一节点,并获取相应的信息。那么能够经过遍历dom树的全部节点进行查找。这样作显然比较麻烦。dom

因而有了XPat语言来访问树的节点比较容易。ui

如:lua

<config>
.....
 <user>
      <name>JIMI</name>
      <gental>male</gental>
 </user>
.....
</config>


 

下列的操做:code

1,获得文档的节点。xml

2,枚举它的子元素。

3,定位user元素。

4,获取user元素的第一个元素,即name元素

5,获取name元素的第一元素,即name标签里的内容。(Text节点)

6,获取Text节点的数据。

XPath能够用来描述XML文档中的一组节点。如:

/gridbag/row

表示根元素gridbag的子元素中全部的row元素。能够用[]操做符来选择特定的元素。

/gridbag/row[1]

表示row全部元素的第一元素。

使用@操做符能够获得元素的属性。(<user id="1"></user>:其中的id就是user元素的属性)

/gridbag/row[1]/cell[1]/@author

上面的XPath描述了第一行第一个单元格的author元素。

XPath表达式:/gridbag/row/cell/@author

描述了做为根元素gridbag的子元素行元素中全部的单元格的author属性节点。

3,java中的XPath

java使用XPath对象来操做xml文档

 XPathFactory xpfactory = XPathFactory.newInstance();
    XPath  path = xpfactory.newXPath();

String name = path.evaluate("/config/user/name",(Document)doc);//计算表达获取相应的name

还有如下的操做

Nodelist nodes = (Nodelist) path.evaluate("/gridbag/row",doc,XPathContants.NODESET);//返回的是一组节点。

Node node = (Node) path.evaluate("/gridbag/row[1]",doc,XPathContants.NODE);//返回一个节点。

int count = ((Number) path.evaluate("count(/gridbag/row)",doc,XPathContants.NUMBER)).intValue();//返回节点个数。

若是想要从某个节点,或者节点列计算获得一个节点能够经过:

reusult = path.evaluate(expression,node);来获取。

--------------------------------------下面是doc变量的建立过程。-------------

  DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
     DocumentBuilder    builder = factory.newDocumentBuilder();

 File f = new File(); Document    doc = builder.parse(f);  

相关文章
相关标签/搜索