- Java XML 教程
- Java XML 首页
- Java XML 概述
- Java XML 解析器
- Java DOM 解析器
- Java DOM 解析器
- 解析 XML 文档
- 查询 XML 文档
- 创建 XML 文档
- 修改 XML 文档
- Java SAX 解析器
- Java SAX 解析器
- 解析 XML 文档
- 查询 XML 文档
- 创建 XML 文档
- 修改 XML 文档
- JDOM XML 解析器
- JDOM XML 解析器
- 解析 XML 文档
- 查询 XML 文档
- 创建 XML 文档
- 修改 XML 文档
- Java StAX 解析器
- Java StAX 解析器
- 解析 XML 文档
- 查询 XML 文档
- 创建 XML 文档
- 修改 XML 文档
- Java XPath 解析器
- Java XPath 解析器
- 解析 XML 文档
- 查询 XML 文档
- 创建 XML 文档
- 修改 XML 文档
- Java DOM4J 解析器
- Java DOM4J 解析器
- 解析 XML 文档
- 查询 XML 文档
- 创建 XML 文档
- 修改 XML 文档
- Java XML 有用资源
- Java XML - 问题与解答
- Java XML - 快速指南
- Java XML - 有用资源
- Java XML - 讨论
Java XPath 解析器 - 查询 XML 文档
Java XPath 是一个 Java API,它帮助我们使用 XPath 表达式查询 XML 文档。使用 XPath 表达式,可以实现元素的随机访问,因此我们可以从 XML 文档中选择特定的节点。这使得文档查询更加灵活。
在本章中,我们使用带有谓词的 XPath 表达式,例如 '/cars/carname/@company'、'/class/student[@rollno = '493']',并通过各种详细示例来查询 XML 文档。
使用 Java XPath 解析器查询 XML
以下是使用 Java XPath 解析器查询文档时使用的步骤:
- 步骤 1:创建 DocumentBuilder
- 步骤 2:读取 XML
- 步骤 3:从文件或流创建文档
- 步骤 4:构建 XPath
- 步骤 5:准备和评估 XPath 表达式
- 步骤 6:迭代 NodeList
- 步骤 7:查询元素
请参考本节的 解析 XML 文档 一章了解前六个步骤。
步骤 7:查询元素
使用 XPath 查询 XML 文档与解析 XML 文档的步骤相同,但唯一的区别在于我们准备 XPath 表达式的方式。在查询时,我们会查询特定属性或元素。
按元素名称查询
我们可以根据元素名称在 XPath 表达式中指定元素名称来查询 XML 文档。XPath 表达式 'root_element/element_name' 检索根元素内所有具有指定名称的节点。
示例
以下 cars.xml 文件包含有关七辆汽车的信息,其元素名称为根元素 'cars' 内的 'carname'。我们将查询此 XML 文件以检查是否存在 'Bentley 2' 汽车。
<?xml version = "1.0"?>
<cars>
<carname company="Ferarri" >Ferarri 101</carname>
<carname company="Lamborgini">Lamborgini 001</carname>
<carname company="Lamborgini">Lamborgini 002</carname>
<carname company="Lamborgini">Lamborgini 003</carname>
<carname company="Bentley">Bentley 1</carname>
<carname company="Bentley">Bentley 2</carname>
<carname company="Bentley">Bentley 3</carname>
</cars>
以下 QueryByElements.java 程序读取上述 cars.xml 文件并构建文档。使用 XPath 表达式 '/cars/carname',我们将 carname 元素作为节点获取到 nodeList 中。我们遍历 NodeList 以查找 Bentley 2 汽车。
import java.io.File;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
public class QueryByElements {
public static void main(String[] args) {
try {
//Creating DocumentBuilder
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
//Reading the XML
File inputFile = new File("cars.xml");
//Creating Document from file or Stream
Document doc = dBuilder.parse(inputFile);
//Building XPath
XPath xPath = XPathFactory.newInstance().newXPath();
//Preparing and Evaluating XPath expression
String expression = "/cars/carname";
NodeList nodeList = (NodeList) xPath.compile(expression).evaluate(
doc, XPathConstants.NODESET);
//Iterating over NodeList
boolean found = false;
for (int i = 0; i < nodeList.getLength(); i++) {
Node nNode = nodeList.item(i);
//Querying the Elements
if(nNode.getTextContent().equals("Bentley 2"))
found=true;
}
if(found)
System.out.println("Bentley 2 car is found");
else
System.out.println("Bentley 2 car is not found");
} catch (Exception e) {
e.printStackTrace();
}
}
}
输出
输出窗口显示已找到 Bentley 2 汽车。
Bentley 2 car is found
按属性查询
要查询元素内的属性,我们使用 XPath 表达式 '/root_element/element_name/@attr_name'。此表达式获取根元素内指定元素的所有具有指定名称的属性。所有这些属性都以 NodeList 中节点的形式存在。
示例 1
我们使用与上一示例中相同的 cars.xml 文件来计算 Bentley 汽车的总数。我们使用了表达式 '/cars/carname/@company' 获取所有 company 属性节点,并通过检查它是否为 'Bentley' 来递增计数变量。
import java.io.File;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
public class QueryByAttributes {
public static void main(String[] args) {
try {
//Creating a DocumentBuilder
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
//Reading the XML
File inputFile = new File("cars.xml");
//Creating Document from file or Stream
Document doc = dBuilder.parse(inputFile);
//Building XPath
XPath xPath = XPathFactory.newInstance().newXPath();
//Preparing and Evaluating XPath expression
String expression = "/cars/carname/@company";
NodeList nodeList = (NodeList) xPath.compile(expression).evaluate(
doc, XPathConstants.NODESET);
//Iterating over NodeList
int count=0;
for (int i = 0; i < nodeList.getLength(); i++) {
Node nNode = nodeList.item(i);
//Querying the Elements
if(nNode.getNodeValue().equals("Bentley"))
count++;
}
System.out.println("Number of Bentley cars found: " + count);
} catch (Exception e) {
e.printStackTrace();
}
}
}
输出
输出窗口显示在 XML 文档中找到的 Bentley 汽车数量。
Number of Bentley cars found: 3
示例 2
我们需要查询以下 studentData.xml 以仅获取与学号为 493 的学生相关的信息。
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>dinkar</firstname>
<lastname>kad</lastname>
<nickname>dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>jasvir</firstname>
<lastname>singn</lastname>
<nickname>jazz</nickname>
<marks>90</marks>
</student>
</class>
在以下 QueryXPathDemo.java 程序中,我们已解析上述 studentData.xml 文件并构建文档。XPath 表达式 '/class/student[@rollno = '493']' 用于获取学号为 493 的学生元素。
import java.io.File;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
public class QueryXPathDemo {
public static void main(String[] args) {
try {
//Creating a DocumentBuilder
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
//Reading the XML
File inputFile = new File("studentData.xml");
//Creating Document from file or Stream
Document doc = dBuilder.parse(inputFile);
//Building XPath
XPath xPath = XPathFactory.newInstance().newXPath();
//Preparing and Evaluating XPath expression
String expression = "/class/student[@rollno = '493']";
NodeList nodeList = (NodeList) xPath.compile(expression).evaluate(
doc, XPathConstants.NODESET);
//Iterating over NodeList
for (int i = 0; i < nodeList.getLength(); i++) {
Node nNode = nodeList.item(i);
System.out.println("\nCurrent Element :" + nNode.getNodeName());
//Getting student info with roll number 493
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
System.out.println("Student roll no : "
+ eElement.getAttribute("rollno"));
System.out.println("First Name : "
+ eElement
.getElementsByTagName("firstname")
.item(0)
.getTextContent());
System.out.println("Last Name : "
+ eElement
.getElementsByTagName("lastname")
.item(0)
.getTextContent());
System.out.println("Nick Name : "
+ eElement
.getElementsByTagName("nickname")
.item(0)
.getTextContent());
System.out.println("Marks : "
+ eElement
.getElementsByTagName("marks")
.item(0)
.getTextContent());
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
输出窗口显示学号为 493 的学生的信息。
输出
Current Element :student Student roll no : 493 First Name : Vaneet Last Name : Gupta Nick Name : vinni Marks : 95