JAVA基于dom4j实现对XML操作「建议收藏」

JAVA基于dom4j实现对XML操作「建议收藏」该篇博客写java基于dom4j来操作xml的一些基本实现,需要用到以下jar包该篇博客目录1、XML特点、语法规则2、XML与HTML区别3、基于dom4j下java实现对XML基本操作一、XML特点、语法规则1、XML特点XML是一种标记语言,很类似HTMLXML的设计宗旨是传输数据,而非显示数据(HTML)XML标签没…

大家好,又见面了,我是你们的朋友全栈君。

该篇博客写java基于dom4j来操作xml的一些基本实现,需要用到以下jar包

这里写图片描述

该篇博客目录

1、XML特点、语法规则
2、XML与HTML区别
3、基于dom4j下java实现对XML基本操作

一、XML特点、语法规则

1、XML特点

  • XML是一种标记语言,很类似HTML
  • XML的设计宗旨是传输数据,而非显示数据(HTML)
  • XML标签没有被预定义,需要自行定义标签(HTML是已经预定义的)
  • XML被设计为具有自我描述性
  • XML是w3c的推荐标准

2、XML语法规则

  • XML不能省略关闭标签
  • XML标签对大小写敏感
  • XML必须正确嵌套
  • XML文档必须有根元素
  • XML的属性值要加”“
  • XML中空格会被保留

二、XML与HTML区别

XML与HTML为不同的目的而设计的

  • XML被设计为传输的存储数据,其焦点是数据的内容
  • HTML被设计为显示数据,其焦点是数据的外观
  • XML旨在传输数据,HTML旨在显示信息

三、基于dom4j下java实现对XML基本操作

可找到官网api https://dom4j.github.io/#top

import java.util.Iterator;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;


public class dom4jtext {

    public static void main(String[] args) {
        System.out.println("Creat XML");
        Document document=CreatXML();
        System.out.println(document.asXML());

        System.out.println("-----------");
        System.out.println("-----------");

        System.out.println("Parsing XML");
        Document document2=ParsingXML();
        System.out.println(document2.asXML());

        System.out.println("-----------");
        System.out.println("-----------");

        System.out.println("iterators XML");
        IteratorsXML();

        System.out.println("-----------");
        System.out.println("-----------");

        System.out.println("XPath XML");
        XPathXML();

        System.out.println("-----------");
        System.out.println("-----------");

        System.out.println("快速循环 XML");
        try {
            SAXReader reader=new SAXReader();
            Document document3=reader.read("XMLtest.xml");
            TreeWalk(document3);
        } catch (DocumentException e) {
            e.printStackTrace();
        }
        System.out.println("-----------");
        System.out.println("-----------");

        System.out.println("String_XML");
        String_XML();

    }

    //Creat XML
    //创建XML
    public static Document CreatXML() {
        Document document=DocumentHelper.createDocument();//创建xml文档
        Element root=document.addElement("root");//创建根元素

        //添加根元素下的子元素及其属性,内容
        Element node1=root.addElement("node").addAttribute("name", "jay").addText("jay zhou");
        Element node2=root.addElement("node").addAttribute("name", "XU").addText("XU LIN JIE");
        return document;
    }

    //Parsing XML
    //解析XML
    //读取XML
    //SAXReader可以通过多种方式读取xml数据,并返回Document格式的对象。
    //通过查看源码,可以看出read()方法接收File,InputStream和URL等格式的参数来读取相应的xml数据。
    public static Document ParsingXML() {
        Document document = null;
        try {
            //创建解析器
            SAXReader reader=new SAXReader();//创建读取文件内容对象
            document=reader.read("XMLtest.xml");//指定文件并读取

        } catch (DocumentException e) {
            e.printStackTrace();
        }
        return document;
    }

    //iterators XML
    //迭代XML
    public static void IteratorsXML() {
        Document document = null;   
        try {
            SAXReader reader=new SAXReader();
            document=reader.read("XMLtest.xml");
        } catch (DocumentException e) {
            e.printStackTrace();
        }
        Element root=document.getRootElement();
        //遍历孩子元素
        for(Iterator<Element> it=root.elementIterator();it.hasNext();)
        {
            Element element=it.next();
            System.out.println(element.asXML());
        }

        System.out.println("-----------");
        System.out.println("-----------");

        //遍历标签为node的元素
        for(Iterator<Element> it=root.elementIterator("node");it.hasNext();)
        {
            Element element=it.next();
            System.out.println(element.asXML());
        }

        System.out.println("-----------");
        System.out.println("-----------");

        //遍历根的属性
        for(Iterator<Attribute> it1=root.attributeIterator();it1.hasNext();)
        {
            Attribute attribute=it1.next();
            System.out.println(attribute.asXML());
        }

    }

    /*
     *使用dom4j支持xpath的操作的几种主要形式
            第一种形式
                /AAA/DDD/BBB: 表示一层一层的,AAA下面 DDD下面的BBB
            第二种形式
                //BBB: 表示和这个名称相同,表示只要名称是BBB,都得到
                        第三种形式
                    /*: 所有元素
                        第四种形式
                BBB[1]: 表示第一个BBB元素
                    BBB[last()]:表示最后一个BBB元素
                        第五种形式
                //BBB[@id]: 表示只要BBB元素上面有id属性,都得到
                        第六种形式
                        //BBB[@id='b1'] 表示元素名称是BBB,在BBB上面有id属性,并且id的属性值是b1 
     */
        /*
         * 在dom4j里面提供了两个方法,用来支持xpath
               selectNodes("xpath表达式"),获取多个节点
               selectSingleNode("xpath表达式"),获取一个节点
         */

    //XPath XML
    //快速找到某个元素(dom4j在解析xml时只能一层一层,所以可结合XPath来提高效率)
    //需要导入jaxen-1.1.6.jar是一个开源的XPath库。Jaxen是一个Java编写的开源的XPath库
    public static void XPathXML() {
        Document document=null;
        try {
            SAXReader reader=new SAXReader();
            document=reader.read("XMLtest.xml");
        } catch (DocumentException e) {
            e.printStackTrace();
        }
        List<Node> list=document.selectNodes("//node");
        for(int i=0;i<list.size();i++)
        {
            System.out.println(list.get(i));
        }
    }

    //Looping XML
    //快速循环XML文档树,比iterators性能高
    public static void TreeWalk(Document document)
    {
        TreeWalk_E(document.getRootElement());
    }
    public static void TreeWalk_E(Element element)
    {
        for(int i=0,size=element.nodeCount();i<size;i++)
        {
            Node node=element.node(i);
            if(node instanceof Element)
            {
                System.out.println(node);
                TreeWalk_E((Element)node);
            }
        }
    }

    //字符串转换为XML
    public static void String_XML() {
        String xmlString="<root><people>man</people></root>";
        try {
            Document document=DocumentHelper.parseText(xmlString);
            System.out.println(document.asXML());
        } catch (DocumentException e) {
            e.printStackTrace();
        }

    }

}

输出结果

Creat XML
<?xml version="1.0" encoding="UTF-8"?>
<root><node name="jay">jay zhou</node><node name="XU">XU LIN JIE</node></root>
-----------
-----------
Parsing XML
<?xml version="1.0" encoding="UTF-8"?>
<root><node name="jay">jay zhou</node><node name="XU">XU LIN JIE</node></root>
-----------
-----------
iterators XML
<node name="jay">jay zhou</node>
<node name="XU">XU LIN JIE</node>
-----------
-----------
<node name="jay">jay zhou</node>
<node name="XU">XU LIN JIE</node>
-----------
-----------
-----------
-----------
XPath XML
org.dom4j.tree.DefaultElement@1ee807c6 [Element: <node attributes: [org.dom4j.tree.DefaultAttribute@2bbaf4f0 [Attribute: name name value "jay"]]/>]
org.dom4j.tree.DefaultElement@5cdd8682 [Element: <node attributes: [org.dom4j.tree.DefaultAttribute@11c20519 [Attribute: name name value "XU"]]/>]
-----------
-----------
快速循环 XML
org.dom4j.tree.DefaultElement@70beb599 [Element: <node attributes: [org.dom4j.tree.DefaultAttribute@4e41089d [Attribute: name name value "jay"]]/>]
org.dom4j.tree.DefaultElement@32a068d1 [Element: <node attributes: [org.dom4j.tree.DefaultAttribute@33cb5951 [Attribute: name name value "XU"]]/>]
-----------
-----------
String_XML
<?xml version="1.0" encoding="UTF-8"?>
<root><people>man</people></root>

工程结构

这里写图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159196.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Google Maps_Google桌面搜索

    Google Maps_Google桌面搜索GoogleBuzz从诞生那天起就跟位置服务紧密连接在了一起,我们可以在移动GoogleMaps里看到大家都在哪里发送Buzz(只要他们发送的时候让Google记录自己的位置),这个功能非常有趣,特别是在某些特殊事件发生之时,可以按照位置看到某个区域里的人们都在想什么做什么(而不是按照timeline的传统方式)。今天,Google在桌面地图服务里也开放了Buzz图层(之…

    2022年10月15日
    0
  • 挖矿区块链_什么是挖矿 带你详细了解挖矿基础知识[通俗易懂]

    挖矿区块链_什么是挖矿 带你详细了解挖矿基础知识[通俗易懂]在信息更迭快速的时代下,人们对于一件事物的新鲜感也是很短暂的,比特币和区块链火了,但是人们对于比特币和区块链的热情一直高涨,为了获得比特币奖励,人们加入到挖矿的大军中,什么是挖矿?也许有些小白对于这个词语还不是很了解,那么下面我们就一起来学习下吧!在进行挖矿之前,我们应该首先知道什么是矿,先举个例子吧,我们在用人民币的时候,都可以发现在每一张人民币上都是有编号的,那么谁可以最先猜出人民币上的编号,…

    2022年5月28日
    35
  • vscode新建文件,默认为html[通俗易懂]

    vscode新建文件,默认为html[通俗易懂]虽然还没达到理想目标,不过还是有进步步骤如下图文字版打开vscode–选择文件–首选项–设置到达设置页面文件(14)–找到要复制代码–复制,在加个html效果如下图右下脚由纯文本变为html…

    2022年8月22日
    21
  • Linux环境MySQL卸载教程「建议收藏」

    Linux环境MySQL卸载教程「建议收藏」Linux环境MySQL卸载

    2022年9月1日
    2
  • python最新激活码2021【在线注册码/序列号/破解码】「建议收藏」

    python最新激活码2021【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月19日
    1.7K
  • eclipse SVN插件的缓存清理[通俗易懂]

    eclipse SVN插件的缓存清理[通俗易懂]工具原料:SVN客户端;windowxp;eclipse中的缓存清理主要有: eclipse清理网页缓存; eclipse清理XSD文件缓存; eclipse清理svn账号缓存; 情况一:eclipse清理网页缓存。修改了代码多次刷新页面[已经清除过浏览器缓存]后页面调试仍显示源代码解决步骤:①停止tomcat的运行;②在eclipse中的Servers下找到并选中tomcat,右键选择”clean…”;③重新启动tomcat,刷新页面;④设置b

    2022年10月14日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号