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