XML引入,DOM 方式解析XML 原理,SAX 方式解析XML

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

相關文章
相關標籤/搜索