1.使用dom4j解析器解析xml

***解析器dom4j是由dom4j组织提供的,针对xml进行解析。dom4j不是Javase的一部分,使用时需要导入dom4j的jar包(官网下载)

  在eclipse里,复制jar包,然后新建文件夹lib粘贴进入,然后单击鼠标右键jar包----->build path----->add to build path

  看到jar包变成奶瓶样子,表示导入成功。

* 得到document对象

      SAXReader reader=new SAXReader();

      Document document=reader.read(url);

*document对象的父接口是Node

      **如果在document对象里找不到想要的方法,就去Node里面去找。

*document里的方法getRootElement():得到根节点,并返Element

*Element也是一个接口,父接口是Node

       **Element和Node里的方法

        getParent():获取父节点

        addElement():添加标签

需求:查询所有name元素里的值

代码:

animal.xml

<?xml version="1.0" encoding="UTF-8"?>
<animal>
<cat id1="sususu">
<name>汤姆</name>
<color>black</color>
<age>10</age>
</cat>
<cat>
<name>丑小鸭</name>
<color>yellow</color>
<age>15</age>
</cat>
</animal>

dom4j.java

package  example4;
import java.io.FileOutputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

class dom4j{
    public static void main(String[] args) throws Exception {
      /*selectName();
        selectOne();
        selectSecond();
        addsex();*/
        addNameBefore();

modifyAge();

  deleteFriend();

}

//查询第一个name元素的值

public static void selectOne() throws Exception {
        SAXReader saxreader = new SAXReader();
        Document document = saxreader.read("src/example4/animal.java");
        Element root = document.getRootElement();
        Element cat = root.element("cat");
        Element name = cat.element("name");
        String s=name.getText();
        System.out.println(s);
    }

//在第一个标签cat的末尾添加一个<sex>男</sex>标签
    public static void addsex() throws DocumentException, Exception {
        SAXReader saxreader=new SAXReader();
        Document document=saxreader.read("src/example4/animal.xml");
        Element root=document.getRootElement();
        //得到第一个cat元素
        Element cat1=root.element("cat");
        //在cat虾米那直接添加元素
        Element sex1=cat1.addElement("sex");
        //在sex下面添加文本
        sex1.setText("男");
        //回写xml

  //这是一个漂亮的格式,可以有缩进的效果
        OutputFormat format=OutputFormat.createPrettyPrint();
        XMLWriter xmlWriter=new XMLWriter(new FileOutputStream("src/example4/animal.xml"), format);    
        xmlWriter.write(document);
        xmlWriter.close();
    }

//在特定位置添加新标签,在第二个cat标签之前添加<friend>丫丫</friend>
    public static void addNameBefore() throws Exception {
        SAXReader saxReader=new SAXReader();
        Document document=saxReader.read("src/example4/animal.xml");
        Element root=document.getRootElement();
        List<Element> list=root.elements("cat");
        //创建元素使用
        Element friend=DocumentHelper.createElement("friend");
        friend.setText("丫丫");
        list.add(1, friend);
        //回写xml
        OutputFormat format=OutputFormat.createPrettyPrint();
        XMLWriter xmlWriter=new XMLWriter(new FileOutputStream("src/example4/animal.xml"), format);
        xmlWriter.write(document);
        xmlWriter.close();
    }

//修改第一个cat下的<age>30</age>
    public static void modifyAge() throws Exception {
        SAXReader saxReader=new SAXReader();
        Document document=saxReader.read("src/example4/animal.xml");
        Element root=document.getRootElement();
        Element cat1=root.element("cat");
        Element age=cat1.element("age");
        age.setText("30");
        OutputFormat format=OutputFormat.createPrettyPrint();
        XMLWriter xmlWriter=new XMLWriter(new FileOutputStream("src/example4/animal.xml"), format);
        xmlWriter.write(document);
        xmlWriter.close();
    }

// 删除第一个cat下面的<fdeleteFriend()riend>丫丫</friend>
    public static void deleteFriend() throws Exception {
        SAXReader saxReader = new SAXReader();
        Document document = saxReader.read("src/example4/animal.xml");
        Element root = document.getRootElement();
        Element friend = root.element("friend");
        // 删除friend元素
        // 通过父元素来删除子元素
        //获取父节点
        //Element parent=friend.getParent();
        root.remove(friend);
        // 这是一个漂亮的格式,可以有缩进的效果
        OutputFormat format = OutputFormat.createPrettyPrint();
        XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/example4/animal.xml"), format);
        xmlWriter.write(document);
        xmlWriter.close();
    }

//获取第一个cat里面的属性的值
    public static void getValues() throws Exception {
        SAXReader saxreader = new SAXReader();
        Document document = saxreader.read("src/example4/animal.xml");
        Element root = document.getRootElement();
        Element cat = root.element("cat");
        //得到属性值
        String id1=cat.attributeValue("id1");
        System.out.println(id1);
    }

// 获取第二个name元素里的值
    public static void selectSecond() throws Exception {
        SAXReader saxreader=new SAXReader();
        Document document=saxreader.read("src/example4/animal.xml");
        Element root=document.getRootElement();
        List<Element> list=root.elements("cat");
        Element cat2=list.get(1);
        Element name2=cat2.element("name");
        String s=name2.getText();
        System.out.println(s);
    }

// 查询xml中所有name元素的值
        public static void selectName() throws Exception {
            // 创建解析器
            SAXReader saxreader = new SAXReader();
            //得到document对象
            Document document=saxreader.read("src/example4/animal.xml");
            //得到根节点
            Element root=document.getRootElement();
            //得到cat结点
            List<Element> list=root.elements("name");
            //得到cat元素下的name元素
            for (Element element: list) {
            //element是每一个cat元素
            //得到cat下面的name元素
            Element name1=element.element("name");
            String s=name1.getText();
            System.out.println(s);    
        }
    }
}

好文要顶 关注我 收藏该文

dom4j解析器sax解析xml文件的更多相关文章

  1. Dom4j解析和sax解析xml

    xml基础知识 1)标签对大小写敏感,2)xml解析方式有两种dom解析和sax解析  3)常用的解析工具有dom的dom4j和sax的sax解析工具 4)文档声明中使用<?xml versio ...

  2. XML 解析---dom解析和sax解析

    眼下XML解析的方法主要用两种: 1.dom解析:(Document Object Model.即文档对象模型)是W3C组织推荐的解析XML的一种方式. 使用dom解析XML文档,该解析器会先把XML ...

  3. Android XML文档解析(一)——SAX解析

    ---------------------------------------------------------------------------------------------------- ...

  4. 使用Dom解析器,操作XML里面的信息

    import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;impo ...

  5. XML解析(二) SAX解析

    XML解析之SAX解析: SAX解析器:SAXParser类同DOM一样也在javax.xml.parsers包下,此类的实例可以从 SAXParserFactory.newSAXParser() 方 ...

  6. XML的概述,.Dom4解析和SAX解析

    1.什么是XML XML 指可扩展标记语言(EXtensible Markup Language) html(hyper text markup langauge) XML 是一种标记语言,很类似 H ...

  7. 死磕Spring之IoC篇 - 解析自定义标签(XML 文件)

    该系列文章是本人在学习 Spring 的过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring 源码分析 GitHub 地址 进行阅读 Spring 版本:5.1. ...

  8. XML解析之SAX解析过程代码详解

    上一篇谢了解析原理和过程,这里应用代码直观认识这个原理: 新建Demo1类: import java.io.File; import javax.xml.parsers.SAXParser; impo ...

  9. 经典面试题:一张表区别DOM解析和SAX解析XML

                                                                                 ============DOM解析    vs ...

随机推荐

  1. 安装Android Studio的问题

    大陆墙内安装最新Android Studio多出了很多问题,不使用VPN的话,注意以下问题: 1 一直停留在fetching Android sdk compoment information界面 A ...

  2. 【Linux】chmod命令

    格式chmod 权限 要修改权限的文件linux中的权限如下: -rw------- (600) -- 只有属主有读写权限. -rw-r--r-- (644) -- 只有属主有读写权限:而属组用户和其 ...

  3. 关于scheduleAtFixedRate方法与scheduleWithFixedDelay的使用

    一.scheduleAtFixedRate方法 该方法是ScheduledExecutorService中的方法,用来实现周期性执行给定的任务,public ScheduledFuture<?& ...

  4. solidity语言2

    变量类型(Value Types) # 布尔型 关键字 bool 值 true , false 操作符 !, &&, ||, ==, != # 整型 关键字 int(int256), ...

  5. C#设计模式之代理模式(一)

    原文地址:http://blog.csdn.net/lovelion/article/details/8227953 代理模式是常用的结构型设计模式之一,当无法直接访问某个对象或访问某个对象存在困难时 ...

  6. Vue2自定义指令改变DOM值后未刷新data中绑定属性的值

    标签(空格分隔): Vue 自定义指令用于过滤输入框,只允许输入数字: Vue.directive('numberOnly', { bind: function (el, binding) { el. ...

  7. Qt 制作2048小游戏

    相信大家都玩过2048把,下面是我用qt写得2048小游戏. 2048.pro HEADERS += \ Widget.h SOURCES += \ Widget.cpp \ main.cpp QT ...

  8. NO.004-2018.02.09《离思五首·其四》唐代:元稹

    离思五首·其四_古诗文网 离思五首·其四 唐代:元稹 曾经沧海难为水,除却巫山不是云.曾经到临过沧海,别处的水就不足为顾:除了巫山,别处的云便不称其为云.曾经:曾经到临.经:经临,经过.难为:这里指“ ...

  9. Scrum _GoodJob

    作为长大的大三老腊肉,我们已经在长大生活了两年多,对于什么是长大人最想完善的校园需求.最想拥有的校园服务媒介也有了更加深切的体会. 于是,GoodJob小团队blingbling闪现啦!! GoodJ ...

  10. 高效实时的网络会议数据传输库—UDT

    在视频会议系统的研发当中,我们的音.视频数据必须要有相应的可靠性作为保障,因为视频会议系统是一个实时性非常强的系统,如果其数据在网络不太好的情况下,有可能会出现丢包.数据延迟.数据堵塞等现象,出现这些 ...