首页 > 代码库 > XML引入,DOM 方式解析XML 原理,SAX 方式解析XML
XML引入,DOM 方式解析XML 原理,SAX 方式解析XML
XML 简介
Xml(eXtensible Markup Language) 即可扩展标记语言。
提供了一套跨平台、跨网络、跨程序的语言的数据描述方式,使用XML 可以方便地实现数据交换、系统配置、
内容管理等常见功能。
元素VS 节点
节点包括元素节点、属性节点、文本节点;
元素一定是节点,但是节点不一定是元素;
<?xml version="1.0" encoding="UTF-8"?> <emp> <empName empNo="10050">Allen</empName> <job>办事员</job> <addr>波士顿</addr> </emp>
DOM 方式解析XML 原理
基于DOM(Document Object Model,文档对象模型)解析方式,是把整个XML 文档加载到内存,转化成
DOM 树,因此应用程序可以随机的访问DOM 树的任何数据;
优点:灵活性强,速度快;
缺点:消耗资源比较多;
DOM 方式解析XML 示例
<?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 方式解析XML
XML引入,DOM 方式解析XML 原理,SAX 方式解析XML
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。