具體的使用方法以下: java
(1)獲得 DOM 解析器的工廠實例 DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance(); node
(2)從 DOM 工廠得到 DOM 解析器 dom
DocumentBuilder dombuilder=domfac.newDocumentBuilder(); ui
(3 )把要解析的 XML 文檔轉化爲輸入流,以便 DOM 解析器解析它 spa
InputStream is= new FileInputStream("test1.xml"); xml
(4)解析 XML 文檔的輸入流,獲得一個 Document 文檔
Document doc=dombuilder.parse(is); get
(5)獲得 XML 文檔的根節點 it
Element root=doc.getDocumentElement(); io
(6)獲得節點的子節點
NodeList books=root.getChildNodes();
- package com.st.demo;
-
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.InputStream;
-
- 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 XmlReader {
- public static void main(String[] args) {
- XmlReader reader = new XmlReader();
- }
- public XmlReader(){
- DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance();
- try {
- DocumentBuilder domBuilder = domfac.newDocumentBuilder();
- InputStream is = new FileInputStream(new File("D:/test1.xml"));
- Document doc = domBuilder.parse(is);
- Element root = doc.getDocumentElement();
- NodeList books = root.getChildNodes();
- if(books!=null){
- for (int i = 0; i < books.getLength(); i++) {
- Node book = books.item(i);
- if(book.getNodeType()==Node.ELEMENT_NODE) {
- //(7)取得節點的屬性值
- String email=book.getAttributes().getNamedItem("email").getNodeValue();
- System.out.println(email);
- //注意,節點的屬性也是它的子節點。它的節點類型也是Node.ELEMENT_NODE
- //(8)輪循子節點
- for(Node node=book.getFirstChild();node!=null;node=node.getNextSibling()) {
- if(node.getNodeType()==Node.ELEMENT_NODE) {
- if(node.getNodeName().equals("name")) {
- String name=node.getNodeValue();
- String name1=node.getFirstChild().getNodeValue();
- System.out.println(name);
- System.out.println(name1);
- }
- if(node.getNodeName().equals("price")) {
- String price=node.getFirstChild().getNodeValue();
- System.out.println(price);
- }
- }
- }
- }
- }
- }
- } catch (Exception e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
-
- }
- }
- <?xml version="1.0" encoding="GB2312" standalone="no"?>
- <books>
- <book email="zhoujunhui">
- <name>rjzjh</name>
- <price>jjjjjj</price>
- </book>
- </books>