亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中使用dom4j解析xml的案例

發布時間:2020-12-08 12:26:23 來源:億速云 閱讀:229 作者:小新 欄目:編程語言

這篇文章將為大家詳細講解有關java中使用dom4j解析xml的案例,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

雖然Java中已經有了Dom和Sax這兩種標準解析方式

但其操作起來并不輕松,對于我這么一個初學者來說,其中部分代碼是活生生的惡心

為此,偉大的第三方開發組開發出了Jdom和Dom4j等工具

鑒于目前的趨勢,我們這里來講講Dom4j的基本用法,不涉及遞歸等復雜操作

Dom4j的用法很多,官網上的示例有那么點兒晦澀,這里就不寫了

首先我們需要出創建一個xml文檔,然后才能對其解析

xml文檔:

<?xml version="1.0" encoding="UTF-8"?> 
<books> 
   <book id="001"> 
      <title>Harry Potter</title> 
      <author>J K. Rowling</author> 
   </book> 
   <book id="002"> 
      <title>Learning XML</title> 
      <author>Erik T. Ray</author> 
   </book> 
</books>

示例一:用List列表的方式來解析xml

import java.io.File;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class Demo {
 public static void main(String[] args) throws Exception {
  SAXReader reader = new SAXReader();
  File file = new File("books.xml");
  Document document = reader.read(file);
  Element root = document.getRootElement();
  List<Element> childElements = root.elements();
  for (Element child : childElements) {
   //未知屬性名情況下
   /*List<Attribute> attributeList = child.attributes();
   for (Attribute attr : attributeList) {
    System.out.println(attr.getName() + ": " + attr.getValue());
   }*/

   //已知屬性名情況下
   System.out.println("id: " + child.attributeValue("id"));

   //未知子元素名情況下
   /*List<Element> elementList = child.elements();
   for (Element ele : elementList) {
    System.out.println(ele.getName() + ": " + ele.getText());
   }
   System.out.println();*/

   //已知子元素名的情況下
   System.out.println("title" + child.elementText("title"));
   System.out.println("author" + child.elementText("author"));
   //這行是為了格式化美觀而存在
   System.out.println();
  }
 }
}

示例二:使用Iterator迭代器的方式來解析xml

import java.io.File;
import java.util.Iterator;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class Demo {
 public static void main(String[] args) throws Exception {
  SAXReader reader = new SAXReader();
  Document document = reader.read(new File("books.xml"));
  Element root = document.getRootElement();

  Iterator it = root.elementIterator();
  while (it.hasNext()) {
   Element element = (Element) it.next();

   //未知屬性名稱情況下
   /*Iterator attrIt = element.attributeIterator();
   while (attrIt.hasNext()) {
    Attribute a  = (Attribute) attrIt.next();
    System.out.println(a.getValue());
   }*/

   //已知屬性名稱情況下
   System.out.println("id: " + element.attributeValue("id"));

   //未知元素名情況下
   /*Iterator eleIt = element.elementIterator();
   while (eleIt.hasNext()) {
    Element e = (Element) eleIt.next();
    System.out.println(e.getName() + ": " + e.getText());
   }
   System.out.println();*/

   //已知元素名情況下
   System.out.println("title: " + element.elementText("title"));
   System.out.println("author: " + element.elementText("author"));
   System.out.println();
  }
 }
}

運行結果:

java中使用dom4j解析xml的案例

示例三:創建xml文檔并輸出到文件

import java.io.File;
import java.io.FileOutputStream;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;

public class Demo {
 public static void main(String[] args) throws Exception {
  Document doc = DocumentHelper.createDocument();
  //增加根節點
  Element books = doc.addElement("books");
  //增加子元素
  Element book1 = books.addElement("book");
  Element title1 = book1.addElement("title");
  Element author1 = book1.addElement("author");

  Element book2 = books.addElement("book");
  Element title2 = book2.addElement("title");
  Element author2 = book2.addElement("author");

  //為子節點添加屬性
  book1.addAttribute("id", "001");
  //為元素添加內容
  title1.setText("Harry Potter");
  author1.setText("J K. Rowling");

  book2.addAttribute("id", "002");
  title2.setText("Learning XML");
  author2.setText("Erik T. Ray");

  //實例化輸出格式對象
  OutputFormat format = OutputFormat.createPrettyPrint();
  //設置輸出編碼
  format.setEncoding("UTF-8");
  //創建需要寫入的File對象
  File file = new File("D:" + File.separator + "books.xml");
  //生成XMLWriter對象,構造函數中的參數為需要輸出的文件流和格式
  XMLWriter writer = new XMLWriter(new FileOutputStream(file), format);
  //開始寫入,write方法中包含上面創建的Document對象
  writer.write(doc);
 }
}

運行結果:

java中使用dom4j解析xml的案例

關于java中使用dom4j解析xml的案例就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

嘉峪关市| 台中县| 五家渠市| 郧西县| 桦南县| 虹口区| 加查县| 长汀县| 沽源县| 信丰县| 景谷| 岳西县| 新龙县| 山西省| 崇阳县| 阿拉尔市| 新昌县| 罗田县| 通江县| 南投市| 城步| 读书| 仙居县| 通榆县| 东兴市| 南召县| 宁河县| 黄大仙区| 永仁县| 保康县| 双鸭山市| 文安县| 金沙县| 农安县| 庆城县| 西平县| 宜兰市| 庐江县| 宁明县| 乌恰县| 太谷县|