XML 簡介html
Xml(eXtensible Markup Language) 便可擴展標記語言。
提供了一套跨平臺、跨網絡、跨程序的語言的數據描述方式,使用XML 能夠方便地實現數據交換、系統配置、
內容管理等常見功能。java
元素VS 節點node
節點包括元素節點、屬性節點、文本節點;
元素必定是節點,可是節點不必定是元素;網絡
<?xml version="1.0" encoding="UTF-8"?> <emp> <empName empNo="10050">Allen</empName> <job>辦事員</job> <addr>波士頓</addr> </emp>
DOM 方式解析XML 原理dom
基於DOM(Document Object Model,文檔對象模型)解析方式,是把整個XML 文檔加載到內存,轉化成
DOM 樹,所以應用程序能夠隨機的訪問DOM 樹的任何數據;
優勢:靈活性強,速度快;
缺點:消耗資源比較多;ide
DOM 方式解析XML 示例ui
<?xml version="1.0" encoding="UTF-8"?> <emps> <emp> <empName empNo="10050">Allen</empName> <job>辦事員</job> <addr>波士頓</addr> </emp> <emp> <empName empNo="10060">Smith</empName> <job>銷售員</job> <addr>紐約</addr> </emp> <emp> <empName empNo="10070">James</empName> <job>技術員</job> <addr>北京</addr> </emp> </emps>
package com.zhiqi.test; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NamedNodeMap; import org.w3c.dom.Node; import org.w3c.dom.NodeList; public class DOM { public static void printNodeAttr(Node node){ NamedNodeMap namedNodeMap=node.getAttributes(); for(int i=0;i<namedNodeMap.getLength();i++){ Node attrNode=namedNodeMap.item(i); System.out.println(attrNode.getNodeName()+":"+attrNode.getFirstChild().getNodeValue()); } } public static void main(String[] args) { DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance(); try { DocumentBuilder builder=factory.newDocumentBuilder(); Document doc=builder.parse("src/emp.xml"); NodeList nodeList=doc.getElementsByTagName("emps"); Element element=(Element)nodeList.item(0); NodeList studentsNodeList=element.getElementsByTagName("emp"); for(int i=0;i<studentsNodeList.getLength();i++){ Element e=(Element)studentsNodeList.item(i); System.out.println("姓名:"+e.getElementsByTagName("empName").item(0).getFirstChild().getNodeValue()); printNodeAttr(e.getElementsByTagName("empName").item(0)); System.out.println("職位:"+e.getElementsByTagName("job").item(0).getFirstChild().getNodeValue()); System.out.println("地址:"+e.getElementsByTagName("addr").item(0).getFirstChild().getNodeValue()); System.out.println("================"); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
SAX 方式解析XMLxml
<?xml version="1.0" encoding="UTF-8"?> <emp> <empName empNo="10050">Allen</empName> <job>辦事員</job> <addr>波士頓</addr> </emp>
package com.zhiqi.test; import java.io.IOException; import javax.xml.parsers.ParserConfigurationException; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; public class SAX extends DefaultHandler{ @Override public void startDocument() throws SAXException { System.out.println("掃描開始"); } @Override public void endDocument() throws SAXException { System.out.println("掃描結束"); } @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { System.out.println("開始掃描元素"+qName); } @Override public void endElement(String uri, String localName, String qName) throws SAXException { System.out.println("結束掃描元素"+qName); } @Override public void characters(char[] ch, int start, int length) throws SAXException { System.out.println("掃描文本節點"+new String(ch,start,length)); } public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException { SAXParserFactory factory=SAXParserFactory.newInstance(); SAXParser parser=factory.newSAXParser(); parser.parse("src/emp2.xml", new SAX()); } }
aaahtm