首先浅聊一下解析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. 解决按 backspace键 出现 ^H 问题

    输入命令 stty erase ^H #stty 时一个用来改变并打印终端行设置的常用命令stty iuclc           #  在命令行下禁止输出大写stty -iuclc          ...

  2. AtCoder Beginner Contest 100 2018/06/16

    A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...

  3. 【LeetCode】016 3Sum Closest

    题目: Given an array S of n integers, find three integers in S such that the sum is closest to a given ...

  4. 洛谷P1080(NOIP2012)国王游戏——贪心排序与高精度

    题目:https://www.luogu.org/problemnew/show/P1080 排序方法的确定,只需任取两个人,通过比较与推导,可以得出ai*bi小的人排在前面: 高精度写的时候犯了些细 ...

  5. python使用uuid生成唯一id或str

    介绍: UUID是128位的全局唯一标识符,通常由32字节的字符串表示. 使用: import uuid print uuid.uuid1() 14bfe806-f1c7-11e6-83b5-0680 ...

  6. AI-Info-Micron-Insight:案例分析:美光使用数据和人工智能来发现、倾听和感觉

    ylbtech-AI-Info-Micron-Insight:案例分析:美光使用数据和人工智能来发现.倾听和感觉 1.返回顶部 1. 案例分析:美光使用数据和人工智能来发现.倾听和感觉 内存芯片制造商 ...

  7. SQL 排序规则问题

    http://blog.csdn.net/delphigbg/article/details/12744807 MSSQL排序规则总结   什么是排序规则呢? 排序规则根据特定语言和区域设置标准指定对 ...

  8. PCL中有哪些可用的PointT类型(5)

    博客转载自:http://www.pclcn.org/study/shownews.php?lang=cn&id=270 Narf36 - float x, y, z, roll, pitch ...

  9. 《Java多线程编程核心技术》读后感(十一)

    方法join的使用 在很多情况下,主线程创建并启动子线程,如果子线程中要进行大量的耗时运算,主线程往往将早于子线程结束之前结束.这时,如果主线程想等待子线程执行完之后再结束,比如子线程处理一个数据,主 ...

  10. 9. 那些强悍的PHP一句话后门

    强悍的PHP一句话后门 这类后门让网站.服务器管理员很是头疼,经常要换着方法进行各种检测,而很多新出现的编写技术,用普通的检测方法是没法发现并处理的.今天我们细数一些有意思的PHP一句话木马. 利用4 ...