欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java dom4j生成與解析XML案例詳解

 更新時間:2021年08月24日 09:01:02   作者:ouyangjun__  
這篇文章主要介紹了Java dom4j生成與解析XML案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

一)dom4j介紹

使用方式:在pom.xml中導(dǎo)入dom4j對應(yīng)的jar

<dependency>
    <groupId>dom4j</groupId>
    <artifactId>dom4j</artifactId>
    <version>1.6.1</version>
</dependency>

優(yōu)點:dom4j使Java生成和解析XML靈活性變高,并且代碼易于維護(hù)

API操作類:

  • Document:表示xml文檔信息,是一個樹形結(jié)構(gòu)
  • Eelment:表示xml的元素結(jié)點,提供一些操作其子元素方法的,如文本、屬性、名稱空間等
  • Attribute:表示元素結(jié)點中的屬性

二)dom4j生成xml

實現(xiàn)步驟:

第一步:創(chuàng)建一個Document實例

Document doc = DocumentHelper.createDocument();

第二步:先添加一個根結(jié)點,然后再添加子結(jié)點,構(gòu)造成一個樹形結(jié)構(gòu)

Element root = doc.addElement("root");

第三步:添加xml文件樣式(也可自定義樣式),并輸出xml文件到指定的路徑下

OutputFormat format = OutputFormat.createPrettyPrint();

XMLWriter writer = new XMLWriter(new FileOutputStream(file), format);
writer.write(doc);

實現(xiàn)源碼:

package com.oysept.xml;
 
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
 
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
import org.jdom2.output.Format;
 
/**
 * dom4j生成xml
 * @author ouyangjun
 */
public class CreateDom4j {
 
    public static void main(String[] args) {
        // 執(zhí)行dom4j生成xml方法
        createDom4j(new File("E:\\dom4j.xml"));
    }
	
    public static void createDom4j(File file) {
        try {
            // 創(chuàng)建一個Document實例
            Document doc = DocumentHelper.createDocument();
			
            // 添加根節(jié)點
            Element root = doc.addElement("root");
			
            // 在根節(jié)點下添加第一個子節(jié)點
            Element oneChildElement= root.addElement("person").addAttribute("attr", "root noe");
            oneChildElement.addElement("people")
                    .addAttribute("attr", "child one")
                    .addText("person one child one");
            oneChildElement.addElement("people")
                    .addAttribute("attr", "child two")
                    .addText("person one child two");
			
            // 在根節(jié)點下添加第一個子節(jié)點
            Element twoChildElement= root.addElement("person").addAttribute("attr", "root two");
            twoChildElement.addElement("people")
                    .addAttribute("attr", "child one")
                    .addText("person two child one");
            twoChildElement.addElement("people")
                    .addAttribute("attr", "child two")
                    .addText("person two child two");
			
            // xml格式化樣式
            // OutputFormat format = OutputFormat.createPrettyPrint(); // 默認(rèn)樣式
			
            // 自定義xml樣式
            OutputFormat format = new OutputFormat();
            format.setIndentSize(2);  // 行縮進(jìn)
            format.setNewlines(true); // 一個結(jié)點為一行
            format.setTrimText(true); // 去重空格
            format.setPadText(true);
            format.setNewLineAfterDeclaration(false); // 放置xml文件中第二行為空白行
			
            // 輸出xml文件
            XMLWriter writer = new XMLWriter(new FileOutputStream(file), format);
            writer.write(doc);
            System.out.println("dom4j CreateDom4j success!");
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

XML文件效果圖:

三)dom4j解析xml

實現(xiàn)步驟:

第一步:創(chuàng)建一個SAXReader解析器

SAXReader reader = new SAXReader();

第二步:解析xml文件,重新構(gòu)建成一個Document對象

Document doc = reader.read(file);

第三步:處理Document對象信息,在控制臺打印

實現(xiàn)源碼:

package com.oysept.xml;
 
import java.io.File;
import java.util.Iterator;
import java.util.List;
 
import org.dom4j.Attribute;
import org.dom4j.CDATA;
import org.dom4j.Comment;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.Text;
import org.dom4j.io.SAXReader;
 
/**
 * dom4j解析xml
 * @author ouyangjun
 */
public class ParseDom4j {
 
    public static void main(String[] args) {
        // 執(zhí)行dom4j解析xml方法
        parseDom4j(new File("E:\\dom4j.xml"));
    }
	
    public static void parseDom4j(File file) {
        try {
            // 創(chuàng)建一個SAXReader解析器
            SAXReader reader = new SAXReader();
			
            // 讀取xml文件,轉(zhuǎn)換成Document結(jié)點
            Document doc = reader.read(file);
 
            // 遞歸打印xml文檔信息
            StringBuffer buffer = new StringBuffer();
            parseElement(doc.getRootElement(), buffer);
            System.out.println(buffer.toString());
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }
	
    @SuppressWarnings("unchecked")
    public static void parseElement(Element element, StringBuffer buffer) {
        buffer.append("<"+element.getName());
        List<Attribute> attrs = element.attributes();
        if (attrs != null) {
            for (Attribute attr : attrs) {
                buffer.append(" "+attr.getName()+"=\""+attr.getValue()+"\"");
            }
        }
        buffer.append(">");
        
        Iterator<Node> iterator = element.nodeIterator();
        while (iterator.hasNext()) {
            Node node = iterator.next();
            if (node instanceof Element) {
                Element eleNode = (Element) node;
                parseElement(eleNode, buffer);
            }
            if (node instanceof Text) {
                Text text = (Text) node;
                buffer.append(text.getText());
            }
            if (node instanceof CDATA) {
                CDATA dataNode = (CDATA) node;
                buffer.append(dataNode.getText());
            }
            if (node instanceof Comment) {
                Comment comNode = (Comment) node;
                buffer.append(comNode.getText());
            }
        }
        buffer.append("</"+element.getName()+">");
    }
}

XML文件解析效果圖打?。?/p>

到此這篇關(guān)于Java dom4j生成與解析XML案例詳解的文章就介紹到這了,更多相關(guān)Java dom4j生成與解析XML內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot配置文件高級用法實戰(zhàn)分享

    SpringBoot配置文件高級用法實戰(zhàn)分享

    Spring Boot配置文件的優(yōu)先級是一個重要的概念,它決定了當(dāng)存在多個配置文件時,哪個配置文件中的配置將被優(yōu)先采用,本文給大家介紹了SpringBoot配置文件高級用法實戰(zhàn),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-08-08
  • Spring Native實現(xiàn)0.059s啟動一個SpringBoot項目

    Spring Native實現(xiàn)0.059s啟動一個SpringBoot項目

    Spring Native是Spring框架的一個子項目,旨在提供一種將Spring應(yīng)用程序編譯為本地可執(zhí)行文件的方法,從而提高啟動時間和資源效率,本文主要介紹了Spring Native實現(xiàn)0.059s啟動一個SpringBoot項目,感興趣的可以了解一下
    2024-02-02
  • 兩萬字詳解Java Sring String的常見操作以及StringBuffer StringBuilder的區(qū)別

    兩萬字詳解Java Sring String的常見操作以及StringBuffer StringBuilder的區(qū)別

    本篇文章帶你認(rèn)識Sring、String的常見操作和StringBuffer 與StringBuilder的區(qū)別(字符串詳解),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • JVM內(nèi)存分配及String常用方法解析

    JVM內(nèi)存分配及String常用方法解析

    這篇文章主要介紹了JVM內(nèi)存分配及String常用方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • Java中EnumSet代替位域代碼詳解

    Java中EnumSet代替位域代碼詳解

    這篇文章主要介紹了Java中EnumSet代替位域代碼詳解,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • 最新評論