首先使用DOM解析XML文件,通过DocumentBuilder读取文档并获取book节点列表,然后遍历每个book元素,调用getAttribute方法获取id和category属性值,同时提取title和author的文本内容,最后输出所有信息。关键步骤包括创建DocumentBuilderFactory、解析XML、调用getElementsByTagName和getAttribute方法,确保正确处理异常和文件路径。

在Java中读取XML节点的属性值,通常使用DOM(Document Object Model)解析方式,这种方式将整个XML文档加载到内存中,形成一棵节点树,便于遍历和操作。以下是具体实现步骤和示例代码。
1. 准备XML文件
假设有一个名为books.xml的文件,内容如下:
<?xml version=”1.0″ encoding=”UTF-8″?>
<library>
<book id=”1″ category=”fiction”>
<title>Java编程思想</title>
<author>Bruce Eckel</author>
</book>
<book id=”2″ category=”tech”>
<title>Effective Java</title>
<author>Joshua Bloch</author>
</book>
</library>
2. 使用DOM解析XML并获取属性值
通过DocumentBuilderFactory和DocumentBuilder创建文档对象,然后遍历节点,调用getAttributes()方法获取属性。
示例代码:

夸克 · 造点AI
325
查看详情
<font face="Courier New,Courier,monospace">import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
public class ReadXMLAttributes {
public static void main(String[] args) {
try {
// 创建解析器工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
// 解析XML文件
Document doc = builder.parse("books.xml");
// 获取所有book节点
NodeList nodeList = doc.getElementsByTagName("book");
// 遍历每个book节点
for (int i = 0; i < nodeList.getLength(); i++) {
Node node = nodeList.item(i);
if (node.getNodeType() == Node.ELEMENT_NODE) {
Element element = (Element) node;
// 获取属性值
String id = element.getAttribute("id");
String category = element.getAttribute("category");
// 获取子节点文本内容
String title = element.getElementsByTagName("title").item(0).getTextContent();
String author = element.getElementsByTagName("author").item(0).getTextContent();
System.out.println("ID: " + id);
System.out.println("Category: " + category);
System.out.println("Title: " + title);
System.out.println("Author: " + author);
System.out.println("---");
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}</font>
3. 关键方法说明
- getAttribute(” attributeName “):直接通过属性名获取属性值,返回字符串。若属性不存在,返回空字符串。
-
getAttributes():返回
NamedNodeMap,可用于遍历所有属性。 - getElementsByTagName():根据标签名获取节点列表。
如果想遍历某个元素的所有属性,可以这样写:
立即学习“Java免费学习笔记(深入)”;
<font face="Courier New,Courier,monospace">NamedNodeMap attrs = element.getAttributes();
for (int j = 0; j < attrs.getLength(); j++) {
Node attr = attrs.item(j);
System.out.println(attr.getNodeName() + " = " + attr.getNodeValue());
}</font>
基本上就这些。只要正确加载XML并定位到目标元素,获取属性值非常直接。注意处理异常和路径问题,确保XML文件可被程序访问。不复杂但容易忽略细节。
大家都在看:
XML数据绑定是什么?如何映射到Java对象?
Java解析XML有哪些方法?
XML的XQuery脚本怎么嵌入到Java应用中执行?
如何使用Java的JAXB实现XML和Java对象互相转换?
































暂无评论内容