`
zhouzaibao
  • 浏览: 294146 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

jdom结合xpath读取xml数据内容

阅读更多
        上次说到如果XML文件的层次比较多,直接通过 getChild() 方法获得元素将会是一件很痛苦的事情,用XPATH来处理就方便多了。JDOM从V1.0bata10版中,已经加入了对XPATH
的支持。(拖了好久,今天总算是补上了。)
XPATH基础
         XPATH遵循文档对象模型(DOM)的路径格式,基本语法由表达式构成。在计算表达式的值之后产生一个对象,这种对象有以下四种基本类型:节点集合、布尔型、数字型和字符
串型。XPATH基本上和在文件系统中寻找文件类似,如果路径是以"/"开头的,就表明该路径表示的是一个绝对路径,这和在UNIX系统中关于文件路径的定义是一致的。以"//"开头
则表示在文档中的任意位置查找。
         以样例XML文档(friends.xml)为例来了解XPATH:
<?xml version="1.0" encoding="UTF-8"?>
<friends comment="Friends List">
	<friend number="1">
		<name>zoof</name>
		<sex value="male" />
		<phone>87654321</phone>
	</friend>
	<friend number="2">
		<name>joe</name>
		<sex value="male" />
		<phone>87654322</phone>
	</friend>
	<friend number="3">
		<name>joe</name>
		<sex value="female" />
		<phone>87654323</phone>
	</friend>
</friends>
 
         在XML文档中使用位置路径表达式来查找信息,这些表达式有很多种组成方式。一般我们用得最多的恐怕是 节点元素 查找。XPATH中用正斜杠(/)来分隔子结点,返回所有与
模式相匹配的元素。下面以几个 表达式 的例子来说明一下返回结果:
        表达式:/friends/friend
        返回:根元素friends下所有的 friend 元素(或节点)。(当然本例只有一个啦!)
        表达式:/friends/*
        返回:根元素friends下所有的元素(或节点)。(“*”相当于通配符,表示“所有”的)
        表达式://friend
        返回:任意元素(或节点)下的所有 friend 元素(或节点)。(注意:不仅仅是1中 根元素friends下面的friend元素,如果存在的话)
        表达式:/friends/friend[@number='1']
        返回:根元素下元素名称为 friend,number属性为'1'的全部元素(或节点)。(对于元素或节点的附加元素,比如属性,函数等都要用方括号"[]"扩起来,属性前面要加
上"@"号)
        表达式:/friends/friend/phone[text()='87654321']
        返回:元素friends/friend下电话号码为 87654321 的全部元素。(text()是XPATH的函数,功能是取出当前节点的文本内容,即content。)
        表达式://name/parent::*
        返回:name元素的所有父元素(或节点)。(parent::* 表示这个元素的所有的父节点的集合)
        上面的介绍对于我们一般的应用基本上够用了,如果你需要进一步的深入,请查看W3C发布的关于XAPH的官方资料。
JDOM+XPATH应用
        现在我们开始使用XPATH结合JDOM来操作XML文件了。JDOM的关于XPATH的api只有一个类:Xpath.java,在org.jdom.xpath这个包中。这个类中的核心方法主要是两个静态方法
selectNodes()和selectSingleNode()。前者根据一个xpath语句返回一组节点:List;后者根据一个xpath语句返回符合条件的第一个节点:Object。
           public static List selectNodes(Object arg1,String arg2) throws org.jdom.JDOMException;
           public static Object selectSingleNode(Object arg1,String arg2) throws org.jdom.JDOMException;
      
        在使用XPATH之前,请先确定你的classpath路径里面有如下几个JAR包,如果没有,请从JDOM的发行包中lib目录下copy:
           saxpath.jar
           jaxen-core.jar
           jaxen-jdom.jar

样列JAVA代码:
/*
* Created on 2004-11-17
*
* TODO To change the template for this generated file go to
* Window - Preferences - Java - Code Style - Code Templates
*/
package cyberobject.com.xpath;
import java.io.IOException;
import java.util.List;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.Text;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
import org.jdom.xpath.XPath;
/**
* @author wanghua
*
* TODO To change the template for this generated type comment go to
* Window - Preferences - Java - Code Style - Code Templates
*/
public class XpathSample {
	public static void main(String[] args) throws JDOMException, IOException{
		SAXBuilder sb = new SAXBuilder();
		Document doc = sb.build("friends.xml");
		Element root = doc.getRootElement();
	  
		List list = XPath.selectNodes(root,"/friends/friend");
	  
		System.out.println("[info] Friends List:");
		for(int ii = 0; ii < list.size(); ii++){
		 Element element = (Element)list.get(ii);
		 String number = element.getAttributeValue("number");
	   
		 //String name = element.getChildText("name");
		 String name = ( (Text) XPath.selectSingleNode(element,"//friend[@number='" + number + "']/name/text()")).getTextNormalize();
		 //String sex = element.getChild("sex").getAttributeValue("value");
		 String sex = ((Element)XPath.selectSingleNode(element,"//friend[@number='" + number + "']/sex")).getAttributeValue("value");
	   
		 //String phone = element.getChildText("phone");
		 String phone = ( (Text) XPath.selectSingleNode(element,"//friend[@number='" + number + "']/phone/text()")).getText();
	   
		 System.out.println("No."+number);
		 System.out.println(" Name:[" + name + "]");
		 System.out.println(" Sex:[" + sex + "]");
		 System.out.println(" Phone:[" + phone + "]");
		 System.out.println();
		}  
		System.out.println("[info] End of Friends List.");
	}
}
 
输出结果:
[info] Friends List:
No.1
Name:[zoof]
Sex:[male]
Phone:[87654321]
No.2
Name:[joe]
Sex:[male]
Phone:[87654322]
No.3
Name:[joe]
Sex:[female]
Phone:[87654323]
[info] End of Friends List.
分享到:
评论

相关推荐

    xpath读取XML节点

    总之,XPath和JDOM结合使用,为Java开发者提供了一种强大而灵活的方式来处理XML数据。理解XPath语法,掌握JDOM的API,将使你在处理XML文档时更加得心应手。在实际项目中,你可以根据需求调整和优化这些基本步骤,...

    JDOM中XPath.selectNodes()和XPath.selectSingleNode()用法

    在实际应用中,JDOM结合XPath可以极大地提高处理XML文档的效率和灵活性。例如,你可以在Web服务、配置文件处理、数据交换等多个场景中利用它们的功能。了解并熟练掌握这两个方法,将有助于你更好地驾驭XML文档的处理...

    基于jdom的xpath解析数据

    结合JDOM和XPath,开发者可以快速、灵活地从XML文档中提取所需信息。然而,需要注意的是,虽然XPath提供了强大的功能,但过度使用复杂的XPath表达式可能导致性能下降,因为每个表达式都需要解析和编译。因此,合理...

    jdom 读取XML 文件

    在IT领域,XML(eXtensible Markup Language)是一种用于存储和传输数据的标准化格式,尤其在处理结构化数据时...在实际应用中,结合JDOM与其他工具,如XPath表达式来查询XML数据,可以进一步提高代码的灵活性和效率。

    XML解析,简单易学(Jdom+XPath): 精简Demo(含jar包).rar

    例如,获取XML中的特定元素: ```java SAXBuilder builder = new SAXBuilder(); File xmlFile = new File("path_to_your_xml_file.xml"); Document document = builder.build(xmlFile); Element rootElement = ...

    jdom1.1.3xml解析工具类

    org.jdom包含了所有的xml文档要素的java类 org.jdom.adapters包含了与dom适配的java类 org.jdom.filter包含了xml文档的过滤器类 org.jdom.input包含了读取xml文档的类 org.jdom.output包含了写入xml文档的类 org....

    JDOM读取XML,并且创建XML

    `getRootElement()`方法用于获取XML文档的根元素。 **创建XML文件:** 创建XML文件时,我们通常会从头开始构建XML结构。以下是基本步骤: 1. 创建`Document`对象,设置其根元素。 2. 添加子元素、属性和其他内容。 ...

    使用JDOM解析XML文件

    通过SAXBuilder或DOMBuilder解析XML,结合XPath查询,我们可以轻松地读取、修改和保存XML数据。在实际应用中,根据项目需求选择合适的解析策略,如需处理大量数据,可考虑使用更优化的XML处理库。

    JDOM使用详解XML及实例

    3. **org.jdom.filter**: 包含XML文档的过滤器类,用于筛选和处理XML内容。 4. **org.jdom.input**: 包含用于读取XML文档的类,如SAXBuilder。 5. **org.jdom.output**: 包含用于输出XML文档的类,如XMLOutputter。 ...

    用jdom解析xml文件

    JDOM是Java中一个专门用来解析XML的库,它提供了方便的API来读取、修改和创建XML文档。在这个例子中,我们将深入探讨如何使用JDOM解析XML文件,并进行遍历与构建。 首先,我们需要了解JDOM的基本概念。JDOM主要由三...

    jdom.jar解析xml

    - **内存效率**:相比于DOM的全文档加载,JDOM可以根据需求选择性地加载部分XML内容,减少了内存消耗。 - **灵活性**:JDOM支持XPath查询,提供了丰富的功能来处理XML文档。 7. **示例应用:JDOM-test** 提供的...

    xpathDemo.zip

    在"xpathDemo"这个项目中,开发者可能创建了一个XML文件,然后使用JDOM加载该文件,接着利用XPath执行一些查询,例如找出所有价格大于特定值的书籍,或者获取某个元素的所有子元素。这样的示例有助于理解如何在实际...

    java jdom解析xml

    - **解析XML**:使用`Document`对象的`getRootElement()`获取XML的根元素,然后可以通过遍历元素、属性和子元素来访问XML数据。 - **写入XML**:如果需要将内存中的JDOM结构写回XML文件,可以使用`...

    JDOM操作xml文件的xmlBean

    通过上述分析可以看出,JDOM不仅提供了简洁的API来处理XML文档,还能够很好地应对常见的读取、修改、添加和删除等操作需求。然而,在实际项目中,根据具体的需求和技术栈选择合适的XML处理工具也是非常重要的。

    jdom从MYSQL导出XML文件

    标题“jdom从MYSQL导出XML文件”表明我们要讨论的是如何使用Java的JDOM库将数据从MySQL数据库导出到XML文件的过程。JDOM是一个专为Java设计的XML处理库,它提供了简单、高效的API来读写XML文档。MySQL则是一种广泛...

    jdom jar下载

    org.jdom包含了所有的xml文档要素的java类 org.jdom.adapters包含了与dom适配的java类 org.jdom.filter包含了xml文档的过滤器类 org.jdom.input包含了读取xml文档的类 org.jdom.output包含了写入xml文档的类 org....

    JDOM对XML文件的读取

    根元素代表XML文档的最外层标签,可以通过`getChildren()`或`getChild()`方法获取子元素,通过`getText()`获取元素文本内容。 ```java Element rootElement = document.getRootElement(); List&lt;Element&gt; child...

    jdom API , XML读取

    JDOM(Java Document Object Model)是一个专为Java设计的XML处理库,它提供了一种高效且方便的方式来...在实际项目中,根据需求选择合适的解析器和方法,结合JDOM提供的工具类,可以实现复杂的数据处理和转换任务。

    JDOM使用详解及实例(解析xml

    JDOM是一个专为Java设计的XML处理库,它结合了SAX和DOM的优点,提供了一种更高效且方便的方式来解析、创建和操作XML文档。JDOM的核心思想是创建一个基于Java对象模型的XML文档表示,使得开发者能够利用Java的强大...

    jdom解析xml文件小实例

    然后,通过`getRootElement()`方法,我们可以获取XML文档的根元素。 进一步,如果我们要遍历XML文件中的所有元素,可以这样做: ```java // 遍历根元素的所有子元素 for (Element child : rootElement.getChildren...

Global site tag (gtag.js) - Google Analytics