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