- 浏览: 157459 次
- 性别:
- 来自: 西安
文章分类
最新评论
-
atgfss:
采用在cookies中保存用户名和sessionid的这种方式 ...
自动登录 -
liumm19870913:
对有输入参数过程的调用
我试过那代码 , 有问题呀,funct ...
oracle 存储过程调用 -
zdsyouxiang:
内容很全面!
认识多任务、多进程、单线程、多线程
类似于使用SQL从数据库从查询数据。XPath可以方便的在XML 文档中查找信息的语言,并在XML文档中对元素和属性进行遍历。XPath 使用路径表达式来选取 XML 文档中的节点或节点集。节点是通过沿着路径 (path) 或者步 (steps) 来选取的。
虽然有很强的表达能力,XPath 并不是 Java 语言,事实上 XPath 不是一种完整的编程语言。有很多东西用 XPath 表达不出来,甚至有些查询也无法表达。幸运的是,可以把 XPath 结合到 Java 程序中,这样就能发挥两者的优势了:Java 做 Java 所擅长的,XPath 做 XPath 所擅长的。
在最初,Java 程序执行 XPath 查询所需要的应用程序编程接口(API)因形形色色的 XPath 引擎而各不相同。Xalan 有一种 API,Saxon 使用另一种,其他引擎则使用其他的 API。这意味着代码往往把您限制到一种产品上。最好能够试验具有不同性能特点的各种引擎,而不会带来不适当的麻烦或者重新编写代码。
幸运的是Java 5 推出了 javax.xml.xpath 包,提供一个引擎和对象模型独立的 XPath 库。这个包也可用于 Java 1.3 及以后的版本,但需要单独安装 Java API for XML Processing (JAXP) 1.3。Xalan 2.7 和 Saxon 8 以及其他产品包含了这个库的实现。
这里先简单介绍下xpath的基本语法,后面再举详细的例子。节点选取语法:
节点路径表达式:
表达式 描述
谓词(用来查找某个特定的节点或者包含某个指定的值的节点,通常使用在[]内)
路径表达式 结果
节点通配符:
通配符 描述
路径组合表达式,组合多个路径表达式,扩大选择范围;例如:
//book/title | //book/price 选取所有 book 元素的 title 和 price 元素。
另外,关于xpath的轴和运算符这里就不再细说了,有兴趣的可以参看后面的参看资料。
下面给出一个实例,展示如何在java中使用xpath提取xml中的信息
xml文件test.xml的内容:
Xml代码
提取xml文件中节点信息的java代码:
解析的步骤如下:
1、获取xml文件
Java代码
InputSource inputSource = new InputSource(new FileInputStream("test.xml"));
//或者使用DOM解析
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.parse("test.xml");
2、接下来创建 XPathFactory:
Java代码
XPathFactory factory = XPathFactory.newInstance();
3、然后使用这个工厂创建 XPath 对象:
Java代码
XPath xPath = factory.newXPath();
4、使用XPath 对象编译 XPath 表达式:
Java代码
XPathExpression expression = xPath.compile("//book/title[@lang=\"en\"]");
5、使用表达式的evaluate(),并处理结果:
Java代码
NodeList list = (NodeList) expression.evaluate(inputSource, XPathConstants.NODESET);
for (int i = 0; i < list.getLength(); i++) {
Node node = list.item(i);
System.out.println(node.getNodeName());
}
evaluate() 方法被声明为返回 Object。实际返回什么依赖于 XPath 表达式的结果以及要求的类型。一般来说,XPath 的
number 映射为 java.lang.Double
string 映射为 java.lang.String
boolean 映射为 java.lang.Boolean
node-set 映射为 org.w3c.dom.NodeList
在 Java 中计算 XPath 表达式时,第二个参数指定需要的返回类型。有五种可能,都在 javax.xml.xpath.XPathConstants 类中命名了常量:
XPathConstants.NODESET
XPathConstants.BOOLEAN
XPathConstants.NUMBER
XPathConstants.STRING
XPathConstants.NODE
在使用xpath解析xml的时候还有很多需要注意的地方,若 XML 文档中的元素在名称空间中,查询该文档的 XPath 表达式必须使用相同的名称空间。XPath 表达式不一定要使用相同的前缀,只需要名称空间 URI 相同即可。事实上,如果 XML 文档使用默认名称空间,那么尽管目标文档没有使用前缀,XPath 表达式也必须使用前缀。另外我们也还可以在java中扩展xpath的函数。更多信息请参看下面的参考资料。
转载 http://berdy.iteye.com/blog/807883
虽然有很强的表达能力,XPath 并不是 Java 语言,事实上 XPath 不是一种完整的编程语言。有很多东西用 XPath 表达不出来,甚至有些查询也无法表达。幸运的是,可以把 XPath 结合到 Java 程序中,这样就能发挥两者的优势了:Java 做 Java 所擅长的,XPath 做 XPath 所擅长的。
在最初,Java 程序执行 XPath 查询所需要的应用程序编程接口(API)因形形色色的 XPath 引擎而各不相同。Xalan 有一种 API,Saxon 使用另一种,其他引擎则使用其他的 API。这意味着代码往往把您限制到一种产品上。最好能够试验具有不同性能特点的各种引擎,而不会带来不适当的麻烦或者重新编写代码。
幸运的是Java 5 推出了 javax.xml.xpath 包,提供一个引擎和对象模型独立的 XPath 库。这个包也可用于 Java 1.3 及以后的版本,但需要单独安装 Java API for XML Processing (JAXP) 1.3。Xalan 2.7 和 Saxon 8 以及其他产品包含了这个库的实现。
这里先简单介绍下xpath的基本语法,后面再举详细的例子。节点选取语法:
节点路径表达式:
表达式 描述
nodename 选取此节点的所有子节点 / 从根节点选取 // 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置 . 选取当前节点 .. 选取当前节点的父节点 @ 选取属性
谓词(用来查找某个特定的节点或者包含某个指定的值的节点,通常使用在[]内)
路径表达式 结果
/bookstore/book[1] 选取属于 bookstore 子元素的第一个 book 元素。 /bookstore/book[last()] 选取属于 bookstore 子元素的最后一个 book 元素。 /bookstore/book[last()-1] 选取属于 bookstore 子元素的倒数第二个 book 元素。 /bookstore/book[position()<3] 选取最前面的两个属于 bookstore 元素的子元素的 book 元素。 //title[@lang] 选取所有拥有名为 lang 的属性的 title 元素。 //title[@lang='eng'] 选取所有 title 元素,且这些元素拥有值为 eng 的 lang 属性。 /bookstore/book[price>35.00] 选取所有 bookstore 元素的 book 元素,且其中的 price 元素的值须大于 35.00。 /bookstore/book[price>35.00]/title 选取所有 bookstore 元素中的 book 元素的 title 元素,且其中的 price 元素的值须大于 35.00。
节点通配符:
通配符 描述
* 匹配任何元素节点 @* 匹配任何属性节点 node() 匹配任何类型的节点
路径组合表达式,组合多个路径表达式,扩大选择范围;例如:
//book/title | //book/price 选取所有 book 元素的 title 和 price 元素。
另外,关于xpath的轴和运算符这里就不再细说了,有兴趣的可以参看后面的参看资料。
下面给出一个实例,展示如何在java中使用xpath提取xml中的信息
xml文件test.xml的内容:
Xml代码
<?xml version="1.0" encoding="ISO-8859-1"?> <bookstore> <book category="COOKING"> <title lang="en">Everyday Italian</title> <author>Giada De Laurentiis</author> <year>2005</year> <price>30.00</price> </book> <book category="CHILDREN"> <title lang="en">Harry Potter</title> <author>J K. Rowling</author> <year>2005</year> <price>29.99</price> </book> <book category="WEB"> <title lang="en">XQuery Kick Start</title> <author>James McGovern</author> <author>Per Bothner</author> <author>Kurt Cagle</author> <author>James Linn</author> <author>Vaidyanathan Nagarajan</author> <year>2003</year> <price>49.99</price> </book> <book category="WEB"> <title lang="zh">Learning XML</title> <author>Erik T. Ray</author> <year>2003</year> <price>39.95</price> </book> </bookstore>
提取xml文件中节点信息的java代码:
Java代码 /** * "/"表示绝对路径 <br/> * "/AA" 所有根节点AA<br/> * "/AA/BB" 所有根节点下的所有BB节点<br/> * * "//" 表示相对路径<br/> * "//BBB" 表示所有的名字为BBB的节点<br/> * "//DDD/BBB" 表示所有父节点为DDD的BBB节点<br/> * * "*" 表示选择所有由星号之前的路径所定位的元素<br/> * "/AAA/CCC/DDD/*" 选择所有路径依附于/AAA/CCC/DDD的元素<br/> * "//*" 选择所有元素 * * "/AAA/BBB[1]" 选择AAA的第一个BBB子元素<br/> * "/AAA/BBB[last()]" 选择AAA的最后一个BBB子元素<br/> * * "//@id" 选择所有的id属性<br/> * "//BBB[@id]" 选择有id属性的BBB元素<br/> * "//BBB[@name]" 选择有name属性的BBB元素<br/> * "//BBB[@*]" 选择有任意属性的BBB元素<br/> * "//BBB[not(@*)]" 选择没有属性的BBB元素<br/> * * "//BBB[@id='b1']" 选择含有属性id且其值为'b1'的BBB元素<br/> * "//BBB[@name='bbb']" 选择含有属性name且其值为'bbb'的BBB元素<br/> * "//BBB[normalize-space(@name)='bbb']" * 选择含有属性name且其值(在用normalize-space函数去掉前后空格后)为'bbb'的BBB元素<br/> * * "//*[count(BBB)=2]" 选择含有2个BBB子元素的元素<br/> * "//*[count(*)=2]" 选择含有2个子元素的元素<br/> * "//*[name()='BBB']" 选择所有名称为BBB的元素(这里等价于//BBB)<br/> * "//*[starts-with(name(),'B')]" 选择所有名称以"B"起始的元素<br/> * "//*[contains(name(),'C')]" 选择所有名称包含"C"的元素<br/> * * "//CCC | //BBB" 选择所有的CCC和BBB元素<br/> * "/AAA/EEE | //BBB" 选择所有的BBB元素和所有是AAA的子元素的EEE元素<br/> */ InputSource inputSource = new InputSource(new FileInputStream("test.xml")); XPathFactory factory = XPathFactory.newInstance(); XPath xPath = factory.newXPath(); XPathExpression expression = xPath.compile("//book/title[@lang=\"en\"]"); NodeList list = (NodeList) expression.evaluate(inputSource, XPathConstants.NODESET); for (int i = 0; i < list.getLength(); i++) { Node node = list.item(i); System.out.println(node.getNodeName()); }
解析的步骤如下:
1、获取xml文件
Java代码
InputSource inputSource = new InputSource(new FileInputStream("test.xml"));
//或者使用DOM解析
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.parse("test.xml");
2、接下来创建 XPathFactory:
Java代码
XPathFactory factory = XPathFactory.newInstance();
3、然后使用这个工厂创建 XPath 对象:
Java代码
XPath xPath = factory.newXPath();
4、使用XPath 对象编译 XPath 表达式:
Java代码
XPathExpression expression = xPath.compile("//book/title[@lang=\"en\"]");
5、使用表达式的evaluate(),并处理结果:
Java代码
NodeList list = (NodeList) expression.evaluate(inputSource, XPathConstants.NODESET);
for (int i = 0; i < list.getLength(); i++) {
Node node = list.item(i);
System.out.println(node.getNodeName());
}
evaluate() 方法被声明为返回 Object。实际返回什么依赖于 XPath 表达式的结果以及要求的类型。一般来说,XPath 的
number 映射为 java.lang.Double
string 映射为 java.lang.String
boolean 映射为 java.lang.Boolean
node-set 映射为 org.w3c.dom.NodeList
在 Java 中计算 XPath 表达式时,第二个参数指定需要的返回类型。有五种可能,都在 javax.xml.xpath.XPathConstants 类中命名了常量:
XPathConstants.NODESET
XPathConstants.BOOLEAN
XPathConstants.NUMBER
XPathConstants.STRING
XPathConstants.NODE
在使用xpath解析xml的时候还有很多需要注意的地方,若 XML 文档中的元素在名称空间中,查询该文档的 XPath 表达式必须使用相同的名称空间。XPath 表达式不一定要使用相同的前缀,只需要名称空间 URI 相同即可。事实上,如果 XML 文档使用默认名称空间,那么尽管目标文档没有使用前缀,XPath 表达式也必须使用前缀。另外我们也还可以在java中扩展xpath的函数。更多信息请参看下面的参考资料。
转载 http://berdy.iteye.com/blog/807883
发表评论
-
java 线程池分析
2015-01-19 17:34 651转自 http://www.cnblogs.com/evilr ... -
JCA 综述
2011-08-25 15:01 1161什么是JCA?它最吸引人 ... -
web.xml 配置详解
2011-08-25 14:14 7221 定义头和根元素 部署描述符文件就像所有XML文件一样, ... -
自动登录
2011-08-17 14:42 1776一、什么是用户自动登录? 对于我们的网站向已注册用户提供 ... -
jad 安装
2011-08-11 14:47 1723Eclipse反编译工具Jad及插件JadClipse配置 ... -
LinkedHashMap 和 HashMap的区别
2011-08-11 10:13 959顾名思义LinkedHashMap是比HashMap多了一个链 ... -
cookie & session
2011-08-10 09:31 569二者的定义: 当你在浏览网站的时候,WEB 服务器会先送一小小 ... -
java异常处理之throw, throws,try和catch
2011-08-05 10:10 1402转载 http://blog.csdn.net/zhouyon ... -
servlet/jsp线程安全
2011-08-05 09:56 1580转自 http://www.newasp.net/tech/ ... -
Static Nested Class 和 Inner Class
2011-07-26 21:54 1130【转】Static Nested Class 和 Inner ... -
servlet 变量范围
2011-07-02 16:19 870如果要在整个应用范围可以用: request.getSessi ... -
tomcat outofmemoryerror permgen space java heap space
2011-06-28 15:07 1344windows 下 tomcat 虚拟内存 ... -
newInstance() 和 new 有什么区别?
2011-06-25 15:51 755在初始化一个类,生成一个实例的时候;newInstance() ... -
几种类加载方式的区别
2011-06-25 15:41 944虚拟机加载类的途径: 1、Dog dog = new Do ... -
运行时异常与一般异常
2011-06-25 15:39 1082Java提供了两类主要的异常:runtime exceptio ... -
ConcurrentHashMap实现原理
2011-06-25 15:14 1966ConcurrentHashMap是Java 5中 ... -
java集合
2011-06-25 15:00 796转载 当你事先不知道要存放数据的个数,或者你需要一种比数组下标 ... -
web.xml 中的listener、 filter、servlet 加载顺序及其详解
2011-06-25 14:21 827转载http://hi.baidu.com/suofang/b ... -
Servlet中listener和filter的总结
2011-06-25 14:04 1431转载 Listener我是这样理 ... -
final 关键字
2011-06-25 09:42 738Java中的final关键字通常 ...
相关推荐
**基于Xpath的XML查询** 1. **选取单个节点**:使用路径表达式,如`/root/element`选取根元素下的`element`节点。 2. **选取多个节点**:使用星号`*`,如`//para`选取文档中所有`para`元素。 3. **选取特定条件的...
【XSLT与XPath查询XML文档详解】 XML(Extensible Markup Language)作为一种强大的数据表示语言,自1998年发布以来,已经成为互联网上数据交换和存储的主要方式。XML允许用户自定义标记,以结构化的方式描述数据,...
XPath是XML文档中查找信息的语言,它允许我们高效地定位到XML文档中的特定节点,如元素、属性或文本。在Java编程中,JDOM库是一个流行的解析和操作XML的工具,它提供了对XPath的支持,使得我们可以方便地通过XPath...
在Java编程环境中,XPath是一种强大的查询语言,用于在XML文档中查找信息。它允许我们根据节点的名称、属性、值或其他特性来定位XML文档中的特定部分。本篇将深入探讨如何在Java中利用XPath来提取XML文档中的数据,...
XPath(XML Path Language)是XML的一个查询语言,用于选取XML文档中的节点。在实验中,XPath用于选取特定的XML元素。例如,`公司"/>` 使用XPath表达式选取当前上下文(即`<联系人>`元素)下的`<公司>`元素内容。...
"采用XPATH在线查询XML文件的搜索引擎源码"这一标题揭示了我们正在探讨的主题,即一个基于XPath的搜索引擎系统,其主要功能是允许用户通过在线方式查询XML文档。XPath(XML Path Language)是一种在XML文档中查找...
XPath是一种在XML文档中查找信息的语言,它是XML处理中的重要工具。XML(eXtensible Markup Language)是一种标记语言,常用于数据交换和存储。CSV(Comma Separated Values)文件则是一种简单、通用的数据格式,...
XPath(XML Path Language)则是用来在XML文档中查找信息的语言,它允许我们通过路径表达式来选取XML节点,如元素、属性、文本等。本篇文章将深入探讨如何使用Dom4j,一个流行的Java库,结合XPath来解析XML文件中的...
在实际开发中,XPath常与DOM或SAX结合使用,先由DOM或SAX解析XML,然后用XPath进行查询。 实例应用: 假设我们有一个XML文件,内容如下: ```xml <name>John Doe <position>Manager <name>Jane Smith ...
XPath,全称XML Path Language,是一种在XML文档中查找信息的语言。它被设计用来选取XML文档中的节点,如元素、属性、文本等。XPath基于XPath 1.0规范,但随着技术发展,也有XPath 2.0和3.1等更新版本。在本篇文章中...
在Java中,我们可以使用javax.xml.xpath.XPath和XPathConstants类来执行XPath查询: ```java import javax.xml.xpath.*; import org.w3c.dom.NodeList; import org.w3c.dom.Node; XPathFactory xPathFactory = ...
XPath(XML Path Language)是一种在XML文档中查找信息的语言,它被设计用来有效地选取XML文档中的节点,包括元素、属性、文本等。XPath使用路径表达式来定位这些节点,类似于文件系统中的路径。它还包含一个标准...
1.可以根据传入的xpath,生成xml,例如:a/b/c : <a><b><c></c></b></a> 2.可以将指定xml字符串添加指定节点 3.xmldocument2String 4.支持属性操作 看到网上几乎没有这样的例子,贡献一下,中国的软件太需要贡献了...
XPath(XML Path Language)是一种用于在XML文档中查找信息的语言,它提供了简便的方式来遍历XML文档结构并提取所需数据。XPath基于XML文档的树状结构,通过路径表达式来定位XML文档中的节点,包括元素、属性、文本...
之前找了好多感觉和自己的需求不太一样,这个可以根据Xpath解析出来xml里所有的信息,十分好用 举个例子 xmlPath = "E://upload/xml/1580242.163.xml"; XPathUtil util = XPathUtil.newInstance(xmlPath); Product ...
标题“xml.rar_XPath查询_xpath”表明这是一个关于使用Java执行XPath查询的压缩包资源。"hooker"可能指的是一个特殊的类或者方法,用于拦截和检查XPath查询的过程,这在调试或者安全审计时非常有用。 描述中的...
libxml2是一个功能强大的XML解析库,它提供了XPath API,可以直接在XML文档上执行XPath查询。使用libxml2时,我们需要先用`xmlParseDoc()`解析XML,得到`xmlDocPtr`,然后调用`xmlXPathNewContext()`创建XPath上下文...
当用户提交表单时,Servlet会接收到包含表单数据的请求,我们可以利用这些数据进行各种操作,比如使用XPath查询XML数据,或者将数据存储到数据库。 综上所述,"XPath递归下降分析 简单Servlet界面"这个主题涵盖了...