java实现xml文件读取并保存到对象

首先浅聊一下解析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;  
        }  
    }

时间: 2024-10-31 04:56:54

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

Java解析XML文件的四种方法

[摘要] 可扩展标志语言(XML)在实现信息标准化.信息的交流与共享上有其独特的技术优势,因此受到了广泛的重视.本文先简单的介绍了XML基本知识,然后从XML应用入手总结了四种现今最常见的XML的解析方法,介绍了这四种方法的特点,其中包括优点与不足之处.最后给出了一个简单的案例来对这四种解析进行代码介绍. [关键字] XML文件,DOM,SAX,JDOM,DOM4J [引言] XML即可扩展标记语言(EXtensible Markup Language),是标准通用标记语言的子集,是一种用于标记

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

在这几天的学习过程中,有开发的朋友告知我,每个编程语言基本都有相应的配置文件支持类,像 Python 编程语言中支持的 ini 文件及其对应的配置文件读取类 ConfigParse,通过这个类,用户可以方便的修改 ini 配置文件.在 Java 中对应的配置文件为 properties 格式的文本文件,其对应的内容格式为 “键=值” ,文本注释信息可以用 “#” 注释.同时 Java 语言中对应的类为 Properties(java.util.Properties),即为读取 propertie

java解析xml文件四种方式介绍、性能比较和基本使用方法

一.介绍: 1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的.DOM以及广义的基于树的处理具有几个优点.首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改.它还可以在任何时候在树中上下导航,而不

自定义类库:Java转换xml文件转化pojo工具

一.之前java读取xml配置文件时,总是通过dom4j第三方库主动解析,最近发现可以通过jdk类库将xml转换pojo. 二.编写xml转化工具类XmlUtils package com.moy.demo.common.utils; import javax.xml.bind.JAXBContext; import javax.xml.bind.Unmarshaller; import java.io.InputStream; import java.io.Reader; import jav

二十、Android -- SDcard文件读取和保存

背景                                                                                            一些东西可以存在自己定义的文件里面,这个文件可以在手机中,可以在SD卡中,在这里就主要介绍一下在SD卡中的存储和读取吧~ 代码                                                                                            

Android–SDcard文件读取和保存

背景                                                                                            一些东西可以存在自己定义的文件里面,这个文件可以在手机中,可以在SD卡中,在这里就主要介绍一下在SD卡中的存储和读取吧~ 代码                                                                                            

用java操作XML文件(DOM解析方式)

XML 可扩展标记语言(Extensible Markup Language),是独立于软件和硬件的传输工具. XML的作用: (1)用作配置文件 (2)简化数据共享 (3)简化数据传输 XML DOM解析方式 在java工程中导入dom4j.jar包. (一)用java读XML文件 <1>创建SAXReader对象. RAXReader reader=new RAXReader(); <2>调用RAXReader的Document read(File file)方法,获取xml文

基于Java的XML文件模拟数据库进行增删改查操作

我们知道XML文件既可以用来进行数据的传输,也可以配合DTD约束文件用来作为配置文件,当然其本质就是一个加了标签以及众多空格保持格式的字符串,那么就可以用Java进行操作. 本例是使用MyEclipse带入DOM4j解析时要用的jar包的基础上做的:当然DOM4j相对于DOM SAX 等解析方式的方便程度是不言而喻的. 下面是本次用例XML文件 <?xml version="1.0" encoding="UTF-8"?> <persons> 

php xml 文件读取 XMLReader

php xml 文件读取 <?php /** $xmlString = '<xml> <persons count="10"> <person username="username1" age="20">this is username1 description</person> <person username="username2" age="20&qu