首页 > 其他 > 详细

XML解析之dom4j

时间:2019-02-11 15:44:16      阅读:162      评论:0      收藏:0      [点我收藏+]

xml解析思想

数据存储在xml文件中,如果想要将其读取到java内存中,这时就需要对xml进行解析,解析xml有下面两个思想:

1.dom

dom会将xml文档加载进内存,形成dom树(document对象),将文档的各个组成部分封装为对象。

优点:可以对dom树进行增删改查。

缺点:dom树非常占内存,解析速度慢。

2.sax

逐行读取,基于事件驱动

优点:不占内存,速度快

缺点:只能读取,不能回写

xml常用解析器

JAXP:sun公司提供的解析器,支持dom和sax,不过使用的不多。

JDOM: DOM4J的前身

DOM4J:全称是dom for java,是jdom的升级版,性能优异,使用较为广泛。

下载dom4j相关的jar包,解压后拷贝到web项目的lib文件夹下

<?xml version="1.0" encoding="UTF-8"?>

<students>
    <student id="1001">
        <name>alex</name>
        <age>20</age>
    </student>
    <student>
        <name>jan</name>
        <age>22</age>
        <![CDATA[
            if(5>3&&3<6)<abc></abc>
        ]]>

    </student>
    <student>
        <name>john</name>
        <age>12</age>
    </student>
    <student>
        <name>marry</name>
        <age>20</age>
    </student>
</students>

读取xml文件:

package firsttomcats;

import java.util.List;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import org.junit.Test;

public class dom4j {
    @Test
    public void test1() throws DocumentException {
        //创建一个xml解析对象
        SAXReader read=new SAXReader();
        //把xml文档加载到document对象中
        Document doc=read.read("src/1.xml");
        //获取根节点
        Element root=doc.getRootElement();
        //获取当前节点的所有子节点
        List list=root.elements();
        Element third=(Element)list.get(2);
        String name=third.element("name").getText();
        System.out.println(name);
    }
    @Test
    public void test2() throws DocumentException {
        //创建一个xml解析对象
        SAXReader reader=new SAXReader();
        //把xml文档加载到document对象中
        Document doct=reader.read("src/1.xml");
        //获取根节点
        Element root=doct.getRootElement();
        select(root);
    }
    //递归
    private void select(Element ele) {
        //输出当前节点的名字
        System.out.println(ele.getName());
        for(int i=0;i<ele.nodeCount();i++) {
            //取出下标为i的节点
            Node node=ele.node(i);
            //判断当前节点是否为标签
            if(node instanceof Element) {
                select((Element) node);
            }else {
                System.out.println(node.getText());
            }
        }
    }
}

XML解析之dom4j

原文:https://www.cnblogs.com/hzdwwzz/p/10361975.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!