XML文件解析

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解析,以及反射我们就可以实现一个简单的框架应用了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值