国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

java DOM4J 讀取XML實例代碼

2019-11-26 15:58:51
字體:
來源:轉載
供稿:網友

下面展示一篇我自己寫的一個XML讀取測試

復制代碼 代碼如下:

import java.util.Iterator;
import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import org.dom4j.*;
import org.dom4j.io.SAXReader;

public class XmlRead {

    static StringBuilder sBuilder = new StringBuilder();

    public static void main(String[] args) throws IOException {

        BufferedReader bReader = new BufferedReader(new InputStreamReader(
                System.in));
        String path = null;
        System.out.println("請輸入XML文件的絕對路徑以及文件名:/n");
        path = bReader.readLine();

        sBuilder.append("開始輸出XML文件內容/n");

        Document document = null;
        try {
            document = read(path);
            sBuilder.append(path + "/n");
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (DocumentException e) {
            e.printStackTrace();
        }

        Element root = getRootElement(document);
        if (root == null) {
            System.out.print("沒有獲取到root節(jié)點");
            return;
        }
        // 獲取XML文檔的編碼格式
        String encString = document.getXMLEncoding();
        sBuilder.append("<?xml version=/"1.0/" encoding=/"" + encString
                + "/">/n");
        sBuilder.append(elementText(root, attText(root), 0));

        System.out.println(getIterator(root, 0) + "</" + root.getName() + ">");

    }

    /**
     * 遞歸節(jié)點
     *
     * @description
     * @param element
     * @param lvl
     *            層級
     * @return
     */
    private static String getIterator(Element element, int lvl) {

        lvl += 1;

        for (Iterator i = element.elementIterator(); i.hasNext();) {
            Element e = (Element) i.next();
            sBuilder.append(elementText(e, attText(e), lvl));
            getIterator(e, lvl);

            int count = e.nodeCount();

            if (count > 0) {
                for (int j = 0; j < lvl; j++) {
                    sBuilder.append("    ");
                }
            }
            sBuilder.append("</" + e.getName() + ">/n");
        }

        return sBuilder.toString();
    }

    /**
     * 獲取當前節(jié)點的屬性的值的字符串
     *
     * @description
     * @param element
     *            當前節(jié)點
     * @return
     */
    private static String attText(Element element) {

        String str = " ";
        for (int i = 0; i < element.attributeCount(); i++) {
            Attribute attribute = element.attribute(i);

            str += attribute.getName() + "=/"" + attribute.getValue() + "/" ";
        }
        return str;
    }

    /**
     * 獲取當前Element的文本值
     *
     * @description
     * @param element
     *            當前Element節(jié)點
     * @param text
     *            屬性值
     * @param lvl
     *            層級
     * @return
     */
    private static String elementText(Element element, String text, int lvl) {
        String str = "";
        for (int i = 0; i < lvl; i++) {
            str += "    ";
        }
        str += "<" + element.getName();
        if (text != null && text != "") {
            str += text;
        }
     //由于dom4j里面沒有 hasChild這個屬性或者方法,所以要用nodeCount()這個方法來判斷時候還有子節(jié)點
        int count = element.nodeCount();
        if (count == 0) {
            return str += ">";
        }
        return str += ">/n";
    }

    /**
     *
     * @description 讀取XML文件
     * @param file
     *            XML文件路徑,包含文件名
     * @return Document 文檔
     * @throws MalformedURLException
     * @throws DocumentException
     */
    public static Document read(String file) throws MalformedURLException,
            DocumentException {

        SAXReader reader = new SAXReader();
        Document document = reader.read(new File(file));
        return document;
    }

    /**
     * 獲取Document文檔的root節(jié)點
     *
     * @param document
     * @return
     */
    public static Element getRootElement(Document document) {
        return document.getRootElement();
    }

}

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 六盘水市| 利川市| 湘乡市| 佛教| 松江区| 双流县| 陕西省| 霸州市| 监利县| 喀什市| 忻州市| 海宁市| 永兴县| 林芝县| 香格里拉县| 凭祥市| 宜昌市| 博野县| 绥德县| 什邡市| 阿拉善左旗| 敦化市| 新田县| 晋江市| 两当县| 卢湾区| 温泉县| 长葛市| 洛扎县| 霍城县| 军事| 麟游县| 芒康县| 廉江市| 河源市| 团风县| 若羌县| 彩票| 漠河县| 郓城县| 大邑县|