首先浅聊一下解析xml的四种方式:

1.DOM方式:有缺点但是这个缺点却也是他的优点。下面详细介绍:

以树形的层次结构组织节点或信息片断集合,可以获得同一个文档中的多处不同数据。使用起来简单。

优点是:可以获得同一个文档中的多处不同数据,使用起来简单。

缺点是:需要加载整个xml文件,这对内存和资源有一定的消耗,如果是小型的xml文件可以尝试用 DOM方式解析。

测试当用DOM方式读取大小为10M的文件时, 将会产生内存溢出异常。

2.SAX方式:在读取数据时检查数据,不用解析整个文档,因此不需要将数据存储在内存中。可以避免DOM方式中的内存溢出。

优点:不用考虑在xml文档在加载时的内存消耗过大。

缺点:在用SAX解析器的时候编码工作会比较困难,而且很难同时访问同一个文档中的多处不同数据。

3.DOM4J方式:DOM4J性能最好,连Sun的JAXM也在用DOM4J.目前许多开源项目中大量采用DOM4J,例如大名鼎鼎的hibernate也用DOM4J来读取XML配置文件。考虑可

DOM4J的可移植性不好。

4.JDOM方式:  JDOM自身不包含解析器。它通常使用SAX2解析器来解析和证输入XML文档

下面是用DOM方式实现xml文件的读取并转化为Java类对象:

DOM方式:

xml文件代码 xmlPojo.xml:

<?xml version="1.0" encoding="UTF-8"?>  
    <items>  
        <item id="328">  
            <name>name1</name>  
            <size>23</size>  
        </item>  
        <item id="303">  
            <name>name2</name>  
            <size>22</size>  
        </item>  
   </items>

xml文件内容对应的java类:

public class XmlPojo{

String id;

String name;

String size;

......

setter AND getter 方法

}

xml读取的实现类:

import java.io.IOException;  
    import java.io.InputStream;  
    import java.util.ArrayList;  
    import java.util.List;  
    import javax.xml.parsers.DocumentBuilder;  
    import javax.xml.parsers.DocumentBuilderFactory;  
    import javax.xml.parsers.ParserConfigurationException;  
    import org.w3c.dom.Document;  
    import org.w3c.dom.Element;  
    import org.w3c.dom.Node;  
    import org.w3c.dom.NodeList;  
    import org.xml.sax.SAXException;  
      
    public class DomTest {  
      
        public static void main(String[] args) {  
            List<XmlPojo> list = new DomTest().parseXmlPojo();  
            //打印读取的结果。  
            for (XmlPojo p : list) {  
                System.out.println(p);  
            }  
      
        }  
          
        //解析xml文件,并把结果封装至XmlPojo的集合中返回  
        private List<XmlPojo> parseXmlPojo() {  
            List<XmlPojo> xmlPojoList = null;  
            try {  
                //获得dom制造工厂  
                DocumentBuilderFactory factory = DocumentBuilderFactory  
                        .newInstance();  
                //获得dom解析器  
                DocumentBuilder builder = factory.newDocumentBuilder();  
                //获得xml文件的输入流  
                InputStream inStream = DomTest.class.getClassLoader()  
                        .getResourceAsStream("xmlPojo.xml");  
                //通过解析器得到Document对象  
                Document document = builder.parse(inStream);  
                //得到要获取的所有item 结点,通过每个结点,获取每个item的内容数据。  
                NodeList list = document.getElementsByTagName("item");  
                xmlPojoList = new ArrayList<XmlPojo>();  
                XmlPojo xmlPojo= null;  
                //遍历person集合,将数据封装于xmlPojo对象中  
                for (int i = 0, size = list.getLength(); i < size; i++) {  
                    xmlPojo = new XmlPojo();  
                    //得到<person>结点  
                    Element e = (Element) list.item(i);  
                    //获取其id属性  
                    String id = e.getAttribute("id");  
                    xmlPojo.setId(Integer.valueOf(id));  
                    //得到当前<person>结点的所有孩子结点。  
                    NodeList chileList = e.getChildNodes();  
                    //遍历所有孩子结点,以便获得其余数据。  
                    for (int j = 0, csize = chileList.getLength(); j < csize; j++) {  
                        Node node = chileList.item(j);  
                        switch (node.getNodeName()) {  
                        case "name":  
                            //当结点为<name>时,获取内容,并给xmlPojo赋值  
                            String name = node.getTextContent();  
                            xmlPojo.setName(name);  
                            break;  
                        case "size":  
                            //当结点为<age>时,获取内容,并给xmlPojo赋值  
                            String size = node.getTextContent();  
                            xmlPojo.setSize(Integer.valueOf(size));  
                            break;  
                        }  
                    }  
                    //完成一个<xmlPojo>结点的遍历,将xmlPojo对象加入集合中。  
                    xmlPojoList.add(xmlPojo);  
                    //清空xmlPojo对象的数据。  
                    xmlPojo = null;  
                }  
      
            } catch (ParserConfigurationException e) {  
                e.printStackTrace();  
            } catch (SAXException e) {  
                e.printStackTrace();  
            } catch (IOException e) {  
                e.printStackTrace();  
            }  
            //返回最终得到的数据。  
            return xmlPojoList;  
        }  
    }

java实现xml文件读取并保存到对象的更多相关文章

  1. java操作XML文件--读取内容

          先把问题贴出来:编写一个可以解析xml及修改xml内容的工具类       由于我以前做过Android应用程序开发,之前也解析过xml文件,所以,这道题不是很难,这篇文章我先解决第一个问 ...

  2. Java 操纵XML之读取XML文件

    Java 操纵XML之读取XML文件 一.JAVA DOM PARSER DOM interfaces The DOM defines several Java interfaces. Here ar ...

  3. xml文件读取到数据库

    xml文件读取到数据库   第一步,导包 c3p0,dom4j,jaxen,MySQL-connector 第二步  xml文件,config文件 第三步 javabean 第四步 c3p0的工具类 ...

  4. java中的文件读取和文件写出:如何从一个文件中获取内容以及如何向一个文件中写入内容

    import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.Fi ...

  5. # java对xml文件的基本操作

    下面是简单的总结三种常用的java对xml文件的操作 1. dom方式对xml进行操作,这种操作原理是将整个xml文档读入内存总,在内存中进行操作,当xml文档非常庞大的时候就会出现内存溢出的异常,这 ...

  6. java对xml文件做增删改查------摘录

    java对xml文件做增删改查 package com.wss; import java.io.File;import java.util.ArrayList;import java.util.Lis ...

  7. Java学习-019-Properties 文件读取实例源代码

    在这几天的学习过程中,有开发的朋友告知我,每个编程语言基本都有相应的配置文件支持类,像 Python 编程语言中支持的 ini 文件及其对应的配置文件读取类 ConfigParse,通过这个类,用户可 ...

  8. Java解析xml文件遇到特殊符号&会出现异常的解决方案

    文/朱季谦 在一次Java解析xml文件的开发过程中,使用SAX解析时,出现了这样一个异常信息: Error on line 60 of document : 对实体 "xxx" ...

  9. php xml 文件读取 XMLReader

    php xml 文件读取 <?php /** $xmlString = '<xml> <persons count="10"> <person ...

随机推荐

  1. 每天一个linux命令(4):pwd命令

    版权声明更新:2017-05-08博主:LuckyAlan联系:liuwenvip163@163.com声明:吃水不忘挖井人,转载请注明出处! 1 文章介绍 本文介绍了Linux下命令cd. 2 开发 ...

  2. Trie 树内存消耗问题

    大家都知道,Trie树(又称字典树)是一种树型数据结构,用于保存大量的字符串.它的优点是:利用字符串的公共前缀来节约存储空间. 相对来说,Trie树是一种比较简单的数据结构,比较易于理解.话说上帝是公 ...

  3. window下的hosts

    存放在windows系统目录中的\system32\drivers\etc下面. hosts文件是用来记录主机ip地址和主机名的对应关系,建立后就可以用主机名来访问主机,而不必记ip地址了.hosts ...

  4. requirejs的打包工具r.js

    不建议用命令行,还是用配置文件比较方便--build.js. 我的build.js文件内容大概如下: ( { appDir : './', baseUrl : './scripts', dir : ' ...

  5. The Tomcat server configuration at \Servers\Tomcat v8.0 Server at localhost-config is missing. Check the server for erro

    解决方案 1.选择Eclipse工具栏中的Windows→Perferences 2.remove已经创建的server 3.选择Add重新添加,选择create anew local server ...

  6. cookie,sessionStorage 和 localStorage

    1.三者之间的区别 cookie是网站为了标示用户身份而储存在用户本地终端(Client Side)上的数据(通常经过加密). cookie数据始终在同源的http请求中携带(即使不需要),记会在浏览 ...

  7. NancyFX 第二章 Rest框架

    正如你看到的,Nancy有两个主要用途. 其中第一项是作为一种通用的基于 REST 框架,可替代 ASP.NET Web API 或其他Rest工具包. 默认情况下,Nancy提供一流的路由和内容协商 ...

  8. simple demo of Handlebars.js & jquery.js

    simple demo of Handlebars.js & jquery.js <html> <head> <script src="jquery-1 ...

  9. backgroundWorker取消后,重新开始就报错:此 BackgroundWorker 当前正忙,无法同时运行多个任务。

    使用BackgroundWorker控件,有2个按钮buttonBegin和buttonCancel.其他都正常,只是在用buttonBegin开始运行,然后点击buttonCancel取消后,到这里 ...

  10. C#中异步及winform中界面假死

    c#中可以用BeginInvoke去启动异步调用,但是有两个BeginInvoke一个是controller的BeginInvoke还有一个是委托的BeginInvoke. 主要区别是controll ...