关于XML的总结(一)
2015-04-26 18:32
92 查看
XML现在已经成为一种通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便。由于会碰到解析XML数据的问题,所以决定总结下解析XML的方法。
当下常用来解析XML文件的方法有两种
第一种是Dom,它的全称是Document Object Model,也即文档对象模型,在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(通常称DOM树),应用程序正是通过对这个对象模型的操作,来实现对XML文档数据的操作。它的优点:整个文档树在内存中,便于操作;支持删除、修改、重新排列等多种功能;缺点:将整个文档调入内存(包括无用的节点),浪费时间和空间;使用场合:一旦解析了文档还需多次访问这些数据;硬件资源充足(内存、CPU)。
第二种是SAX,SAX ,事件驱动。当解析器发现元素开始、元素结束、文本、文档的开始或结束等时,发送事件,程序员编写响应这些事件的代码,保存数据。优点:不用事先调入整个文档,占用资源少;SAX解析器代码比DOM解析器代码小,适于Applet,下载。缺点:不是持久的;事件过后,若没保存数据,那么数据就丢了;无状态性;从事件中只能得到文本,但不知该文本属于哪个元素;使用场合:Applet;只需XML文档的少量内容,很少回头访问;机器内存少;
对于Dom方式:
对于SAX方式
当下常用来解析XML文件的方法有两种
第一种是Dom,它的全称是Document Object Model,也即文档对象模型,在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(通常称DOM树),应用程序正是通过对这个对象模型的操作,来实现对XML文档数据的操作。它的优点:整个文档树在内存中,便于操作;支持删除、修改、重新排列等多种功能;缺点:将整个文档调入内存(包括无用的节点),浪费时间和空间;使用场合:一旦解析了文档还需多次访问这些数据;硬件资源充足(内存、CPU)。
第二种是SAX,SAX ,事件驱动。当解析器发现元素开始、元素结束、文本、文档的开始或结束等时,发送事件,程序员编写响应这些事件的代码,保存数据。优点:不用事先调入整个文档,占用资源少;SAX解析器代码比DOM解析器代码小,适于Applet,下载。缺点:不是持久的;事件过后,若没保存数据,那么数据就丢了;无状态性;从事件中只能得到文本,但不知该文本属于哪个元素;使用场合:Applet;只需XML文档的少量内容,很少回头访问;机器内存少;
对于Dom方式:
public static void main(String[] args) throws Exception { <span style="color:#3333ff;background-color: rgb(255, 204, 204);">// step 1: 获得dom解析器工厂(工作的作用是用于创建具体的解析器) </span> DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance(); <span style="color:#3366ff;background-color: rgb(255, 204, 204);">// step 2:获得具体的dom解析器 </span> DocumentBuilder builder = builderFactory.newDocumentBuilder(); <span style="color:#3333ff;background-color: rgb(255, 204, 204);">// step3: 解析一个xml文档,获得Document对象(根结点) </span> Document document2 = builder.parse(new File("src/com/person.xml")); NodeList list2 = document2.getElementsByTagName("person"); for (int i = 0; i < list2.getLength(); i++) { Element d = (Element) list2.item(i); System.out.println(d.getElementsByTagName("name").item(0).getFirstChild().getNodeValue()); System.out.println(d.getElementsByTagName("age").item(0).getFirstChild().getNodeValue()); System.out.println(d.getElementsByTagName("address").item(0).getFirstChild().getNodeValue()); System.out.println("--------------------------------------"); } } |
<p>public class SaxTest1 { public static void main(String[] args) throws Exception { <span style="color:#3333ff;background-color: rgb(255, 204, 204);"> //step1: 获得SAX解析器工厂实例</span> SAXParserFactory factory = SAXParserFactory.newInstance(); <span style="color:#3333ff;background-color: rgb(255, 204, 204);"> //step2: 获得SAX解析器实例</span> SAXParser parser = factory.newSAXParser(); <span style="color:#3333ff;background-color: rgb(255, 204, 204);"> //step3: 开始进行解析</span> parser.parse(new File("src/com/person.xml"), new MyHandler()); } }</p><p>class MyHandler extends DefaultHandler { @Override public void startDocument() throws SAXException { System.out.println("parse began"); } @Override public void endDocument() throws SAXException { System.out.println("parse finished"); } @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { System.out.println("start element"); } @Override public void endElement(String uri, String localName, String qName) throws SAXException { System.out.println("finish element"); }</p> |
相关文章推荐
- 关于ssh三大框架中web.xml的总结
- 关于ssh三大框架中web.xml的总结
- 关于spring MVC web.xml配置文件的编写总结(持续更新)
- 关于XML的知识点总结
- 关于.NET程序中XML文档注释的总结
- 关于ajax的XMLHttpRequest对象的方法总结
- 关于xml和Json数据解析的一些总结
- 关于xml总结(二)
- 关于ssh三大框架中web.xml的总结
- 关于jsp网页以及web.xml文件配置总结
- 关于XML数据的处理【总结】
- 关于XML的总结——Schema和DTD
- 关于Document生成xml的总结(一)
- 关于xml学习的一点思考与总结
- 关于SAXReader解析XML以及JSONObject和JSONArray的使用总结
- 关于spring MVC web.xml配置文件的编写总结(持续更新)
- 关于dom4j中使用FileWriter构造XMLWriter导致生成的xml中文乱码总结。
- 关于规范xml的xsd文件一点总结
- SQL server 2008 关于XML类型数据 功能总结及性能测试
- SQL server 2008 关于XML类型数据 功能总结及性能测试