XML文件解析

来源:互联网 发布:软件开发包括哪些 编辑:程序博客网 时间:2024/06/07 03:51

xml文件解析
Java对于xml文件解析有四种方法:DOM实现方法,DOM4J实现方法,JDOM实现方法,以及SAX实现方法。
这四种实现方法其原理基本差不多,都是获取到相应的xml文件,并将xml文件中的元素一 一取出,在进行相应操作。

DOM的缺点:
DOM是一次性将文档中的所有内存读取到内存中,如果是文档比较小,在读入内存时能够提高操作速度,但是当文档较大时,则读取比较慢了,因此SAX应运而生,他不是一次性将整个文档读取到内存中的,这对于处理大型文档就方便快捷了。

我就写个DOM的实现方法,其他三种均可根据API来逐步实现:

package cn.test.com;import java.io.File;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;//将xml文件转换成DOM文件public class XMLReaderTest {    public static void main(String[] args) {        Document document = null;        Element element = null;        DocumentBuilder documentBuilder = null;        DocumentBuilderFactory factory = null;        try {            //获取文件路径            File xmlFile = new File("test.xml");            //实例化DocumentBuilderFactory对象            factory = DocumentBuilderFactory.newInstance();            //通过工厂生成DocumentBuilder对象            documentBuilder = factory.newDocumentBuilder();            //将XML文件转换成DOM文件            document = documentBuilder.parse(xmlFile);            //获取DOM文件根元素            element = document.getDocumentElement();            //获取根元素下的所有子节点            NodeList nodeList = element.getChildNodes();            //遍历子节点            for(int i=0;i<nodeList.getLength();i++){                Node node = nodeList.item(i);                //获取该节点的所有属性                NamedNodeMap map = node.getAttributes();                //遍历所有属性                if(map!=null&&map.getLength()>0){                    for(int j=0;j<map.getLength();j++){                        Node attribute = map.item(j);                        //输出属性值                        if("id".equalsIgnoreCase(attribute.getNodeName())){                            System.out.println("id:"+attribute.getNodeValue());                        }else if("class".equalsIgnoreCase(attribute.getNodeName())){                            System.out.println("class:"+attribute.getNodeValue());                        }                    }                }                //获取该节点的所有子节点                NodeList nodeList2 = node.getChildNodes();                //遍历该节点的所有子节点                for(int j=0;j<nodeList2.getLength();j++){                    Node subNode = nodeList2.item(j);                    //输出节点的文本内容                    if("test".equalsIgnoreCase(subNode.getNodeName())){                        System.out.println("test:"+subNode.getTextContent());                    }else if("property".equalsIgnoreCase(subNode.getNodeName())){                        System.out.println("property:"+subNode.getTextContent());                    }                }            }        } catch (Exception e) {            e.printStackTrace();        }    }}

test.xml文件:

<?xml version="1.0" encoding="UTF-8"?><beans>    <bean id="test" class="cn.test.com.ReflectTest">        <test>test 1</test>        <property>perperty 1 </property>    </bean></beans>

通过xml解析,以及反射我们就可以实现一个简单的框架应用了

0 0