DocumentBuilderFactory解析XML,用於建立DOM模式的解析器物件
阿新 • • 發佈:2018-11-29
(1) javax.xml.parsers 包中的DocumentBuilderFactory, DocumentBuilderFactory是一個抽象工廠類,它不能直接例項化,但該類提供了一個newInstance方法 ,這個方法會根據本地平臺預設安裝的解析器,自動建立一個工廠的物件並返回。
(2) 呼叫 DocumentBuilderFactory.newInstance() 方法得到建立 DOM 解析器的工廠。
DocumentBuilderFactory doc=DocumentBuilderFactory.newInstance();
(3) 呼叫工廠物件的 newDocumentBuilder方法得到 DOM 解析器物件。
DocumentBuilder db=doc.newDocumentBuilder();
(4) 把要解析的 XML 文件轉化為輸入流,以便 DOM 解析器解析它
InputStream is= new FileInputStream("test.xml");
(5) 呼叫 DOM 解析器物件的 parse() 方法解析 XML 文件,得到代表整個文件的 Document 物件,進行可以利用DOM特性對整個XML文件進行操作了。
Document doc=dombuilder.parse(is);
(6) 得到 XML 文件的根節點
Element root=doc.getDocumentElement();
(7) 得到節點的子節點
NodeList users=root.getChildNodes();
(8)相關java案例:
1 package com.zsqMybatisOne.Pojo; 2 3 import java.io.File; 4 import java.io.FileInputStream; 5 import java.io.InputStream; 6 import javax.xml.parsers.DocumentBuilder; 7 import javax.xml.parsers.DocumentBuilderFactory; 8 importorg.w3c.dom.Document; 9 import org.w3c.dom.Element; 10 import org.w3c.dom.Node; 11 import org.w3c.dom.NodeList; 12 13 public class XmlReader { 14 15 public XmlReader() { 16 DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance(); 17 try { 18 DocumentBuilder domBuilder = domfac.newDocumentBuilder(); 19 InputStream is = new FileInputStream(new File( 20 "C:/Users/sony/Desktop/test.xml")); 21 Document doc = domBuilder.parse(is); 22 Element root = doc.getDocumentElement(); 23 NodeList users = root.getChildNodes(); 24 if (users != null) { 25 for (int i = 0; i < users.getLength(); i++) { 26 Node user = users.item(i); 27 // TEXT_NODE 說明該節點是文字節點 28 // ELEMENT_NODE 說明該節點是個元素節點 29 if (user.getNodeType() == Node.ELEMENT_NODE) { 30 // (7)取得節點的屬性值 31 // String email = user.getAttributes() 32 // .getNamedItem("email").getNodeValue(); 33 // System.out.println(email); 34 // 注意,節點的屬性也是它的子節點。它的節點型別也是Node.ELEMENT_NODE 35 // (8)輪循子節點 36 for (Node node = user.getFirstChild(); node != null; node = node.getNextSibling()){ 37 if (node.getNodeType() == Node.ELEMENT_NODE) { 38 if (node.getNodeName().equals("name")) { 39 String name = node.getNodeValue(); 40 String name1 = node.getFirstChild() 41 .getNodeValue(); 42 System.out.println("name==" + name); 43 System.out.println("name1==" + name1); 44 } 45 if (node.getNodeName().equals("price")) { 46 String price = node.getFirstChild() 47 .getNodeValue(); 48 System.out.println(price); 49 } 50 } 51 } 52 } 53 } 54 } 55 NodeList node = root.getElementsByTagName("string"); 56 if (node != null) { 57 for (int i = 0; i < node.getLength(); i++) { 58 Node str = node.item(i); 59 String s = str.getFirstChild().getNodeValue(); 60 System.out.println(s); 61 } 62 } 63 } catch (Exception e) { 64 e.printStackTrace(); 65 } 66 } 67 68 public static void main(String[] args) { 69 XmlReader xmlReader = new XmlReader(); 70 } 71 }
(9)xml檔案:
<?xml version="1.0" encoding="GB2312" standalone="no"?> <users> <user email="www.baidu.com"> <name>張三</name> <age>18</age> <sex>男</sex> </user> <user> <name>李四</name> <age>16</age> <sex>女</sex> </user> <user> <name>王五</name> <age>25</age> <sex>不明</sex> </user> </users>