java中的xpath,读取xml文档。

时间:2022-12-22 05:58:13

1,入门

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

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

介于XPointer与XSL间的语法模型。但是 XPath 很快的被开发者采用来当作小型查询语言。

2,了解

如果要定位xml文档中的某一节点,并获取相应的信息。那么可以通过遍历dom树的所有节点进行查找。这样做显然比较麻烦。

于是有了XPat语言来访问树的节点比较容易。

如:

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

下列的操作:

1,得到文档的节点。

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);