Java对Xml文件解析
时间: 2024-02-23 14:29:36 浏览: 77
Java解析Xml文件
Java提供了多种方式来解析XML文件,包括DOM、SAX和StAX等。
1. DOM(Document Object Model)解析:将整个XML文档加载到内存中,形成一棵树形结构,可以通过访问树的节点来获取XML文件中的数据。
2. SAX(Simple API for XML)解析:基于事件驱动的解析方式,逐行读取XML文档,遇到节点开始、结束、属性等事件时触发相应的事件处理器进行处理。
3. StAX(Streaming API for XML)解析:也是基于事件驱动的解析方式,但是与SAX不同的是,它可以在读取节点时进行修改,也可以在遍历时进行跳过,具有更高的灵活性。
下面是一个使用DOM解析XML文件的示例代码:
```java
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
import java.io.File;
public class XmlParser {
public static void main(String argv[]) {
try {
File fXmlFile = new File("file.xml");
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(fXmlFile);
doc.getDocumentElement().normalize();
System.out.println("Root element :" + doc.getDocumentElement().getNodeName());
NodeList nList = doc.getElementsByTagName("student");
System.out.println("----------------------------");
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
System.out.println("\nCurrent Element :" + nNode.getNodeName());
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
System.out.println("Student id : " + eElement.getAttribute("id"));
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("Email : " + eElement.getElementsByTagName("email").item(0).getTextContent());
System.out.println("Marks : " + eElement.getElementsByTagName("marks").item(0).getTextContent());
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
```
该示例代码读取了一个名为“file.xml”的XML文件,遍历其中的“student”节点,并输出每个节点的“id”属性以及“firstname”、“lastname”、“email”和“marks”子节点的文本内容。
阅读全文