1. XPATH基础
XPATH遵循文档对象模型(DOM)的路径格式,基本语法由表达式构成。在计算表达式的值之后产生一个对象,
这种对象有以下四种基本类型:节点集合、布尔型、数字型和字符串型。
XPATH基本上和在文件系统中寻找文件类似,如果路径是以"/"开头的,就表明该路径表示的是一个绝对路径,
这和在UNIX系统中关于文件路径的定义是一致的。以"//"开头则表示在文档中的任意位置查找。
2. 以样例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中用正斜杠(/)来分隔子结点,
返回所有与模式相匹配的元素。
3. 下面以几个 表达式 的例子来说明一下返回结果:
表达式:/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的官方资料。
4. 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:
saxpaht.jar
jaxen-core.jar
jaxen-jdom.jar
5. 样列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.
分享到:
相关推荐
在JDOM中,没有内置的XPath支持,但通过`jdom-contrib`,我们可以将XPath与JDOM结合,实现以下功能: 1. **XPath解析**:`jdom-contrib`提供了`XPathReader`类,可以解析XPath表达式并返回一个匹配的节点集合。这...
JDOM的主要目标是为Java开发者提供一个高性能、灵活且易于使用的XML处理工具,使得XML数据能够与Java对象无缝结合。 **JDOM的两个版本** 在您提供的资源中,包含了JDOM的两个主要版本:jdom-1.1.3.jar和jdom-2.0.6...
在实际应用中,JDOM结合XPath可以极大地提高处理XML文档的效率和灵活性。例如,你可以在Web服务、配置文件处理、数据交换等多个场景中利用它们的功能。了解并熟练掌握这两个方法,将有助于你更好地驾驭XML文档的处理...
**JDOM 2.0.5.jar:XML处理的利器** 在Java开发中,处理XML文档是一项常见的任务。JDOM,全称为Java Document Object Model,是一...结合提供的源程序例子,学习和理解JDOM的用法,可以极大地提升处理XML文档的能力。
7. **扩展性**: 除了基本的XML处理功能,JDOM还允许开发者通过扩展API来实现自定义的行为,如自定义命名空间处理、XPath支持等。 在实际应用中,JDOM常被用于Web服务、配置文件处理、数据序列化等领域。例如,...
结合JDOM和XPath,开发者可以快速、灵活地从XML文档中提取所需信息。然而,需要注意的是,虽然XPath提供了强大的功能,但过度使用复杂的XPath表达式可能导致性能下降,因为每个表达式都需要解析和编译。因此,合理...
压缩包内的资源,如 "在 Java 中使用 DOM 和 XPath 进行有效的 XML 处理.mht" 和 "JDOM-XPATH编程指南.mht",很可能是关于如何在Java中结合DOM和XPath的教程。MHT文件是一种网页归档格式,通常包含HTML内容和相关...
- **事件驱动处理**:JDOM可以通过`ContentHandler`接口,结合SAX解析器实现事件驱动的XML处理。 ### 5. 示例代码 这里展示一个完整的示例,包括创建XML文档、解析XML文档并使用XPath查询: ```java import org....
结合Java的其他库,如Xalan、Xerces等,JDOM可以进一步扩展其功能,例如样式表转换(XSLT)和XML验证。 总结起来,JDOM 2.0.3是一个强大且易用的XML处理工具,它简化了XML在Java应用程序中的使用,提高了开发效率。...
《深入理解JDOM 2.0.2:XML解析利器》 XML(eXtensible Markup Language)是一种标记语言,广泛用于数据...在实际项目中,根据需求选择合适的解析方式,结合JDOM提供的丰富功能,能够有效地提升XML操作的效率和质量。
通过这种方式,JSTL结合XML和XPath,为JSP开发者提供了强大的XML处理能力,使得在JSP中处理XML数据变得既直观又方便。了解并熟练掌握这些技术,对于提高JSP应用的开发效率和质量有着重要的意义。在实际项目中,可以...
DOM4J是一个灵活的Java XML API,它结合了DOM、SAX和JDOM的优点。DOM4J提供了一种更面向对象的方式来处理XML,同时支持SAX解析,可以处理大型文件。DOM4J提供了丰富的功能,如XPath查询、XML Schema验证、文档修改等...
在Java开发中,使用DOM4J或其他类似库(如JDOM、XMLBeans等)结合XPath,可以高效地读取、修改XML数据。这些库提供了API,使得开发者能够轻松地将XPath表达式转换为实际的节点操作,从而实现对XML文档内容的动态查询...
在这个"xpathDemo.zip"中,我们可以看到一个使用JDOM和XPath结合的示例。JDOM允许开发者以一种与XML结构相对应的方式在Java程序中创建和操作XML文档。通过JDOM,你可以创建新的XML文档,修改现有文档,或者查询文档...
在Java开发中,DOM4J和JDOM是两种流行的XML处理库,而`mysql-connector`则是连接MySQL数据库的关键组件。下面将详细讲解这三个库及其在实际开发中的应用。 首先,DOM4J是一个非常强大的Java XML API,它提供了丰富...
JDOM的设计目标是结合SAX和DOM的优点,同时减少它们的不足,使得XML处理更加直观和便捷。 JDOM的核心是基于树形结构的模型,它将XML文档看作一棵由元素、属性、文本等组成的树。这个模型允许开发者以面向对象的方式...
5. **高级功能**:JDOM还支持XPath查询、Namespace管理以及XML Schema验证等高级功能,使XML处理更加便捷。 JDOM1.1虽然在某些方面表现出色,但也有其局限性。例如,对于非常大的XML文档,内存效率可能不如SAX解析...
DOM4J对XPath的支持和对SAX的集成使其在处理复杂XML任务时更具优势。 7. **实际应用**: 在实际开发中,DOM4J常用于配置文件的读写、Web服务的响应解析、数据交换格式的处理等方面。它的灵活性和易用性使其成为...
JDOM 是一个专门为Java设计的XML处理库,它结合了SAX和DOM的优点,提供了一种高效且易于使用的API来创建、解析和操作XML文档。JDOM的主要目标是简化XML处理,通过利用Java语言的强大特性,如方法重载、集合和映射,...
通过SAXBuilder或DOMBuilder解析XML,结合XPath查询,我们可以轻松地读取、修改和保存XML数据。在实际应用中,根据项目需求选择合适的解析策略,如需处理大量数据,可考虑使用更优化的XML处理库。