使用dom4j遞歸解析節(jié)點(diǎn)內(nèi)還含有多個(gè)節(jié)點(diǎn)的xml
dom4j遞歸解析節(jié)點(diǎn)內(nèi)還含有多個(gè)節(jié)點(diǎn)的xml
介紹了dom4j的一些平常使用
dom4j的介紹:
dom4j是一個(gè)Java的XML API,是jdom的升級(jí)品,用來(lái)讀寫XML文件的。dom4j是一個(gè)十分優(yōu)秀的JavaXML API,具有性能優(yōu)異、功能強(qiáng)大和極其易使用的特點(diǎn),它的性能超過(guò)sun公司官方的dom技術(shù),同時(shí)它也是一個(gè)開(kāi)放源代碼的軟件,可以在SourceForge上找到它。在IBM developerWorks上面還可以找到一篇文章,對(duì)主流的Java XML API進(jìn)行的性能、功能和易用性的評(píng)測(cè),所以可以知道dom4j無(wú)論在哪個(gè)方面都是非常出色的。如今可以看到越來(lái)越多的Java軟件都在使用dom4j來(lái)讀寫XML,特別值得一提的是連Sun的JAXM也在用dom4j。這已經(jīng)是必須使用的jar包, Hibernate也用它來(lái)讀寫配置文件。
這里的xml文件為(嵌套了兩層,建在本地,隨便放在哪個(gè)文件夾):
<xml>
<ToUserName><![CDATA[toUser]]></ToUserName>
<FromUserName><![CDATA[fromUser]]></FromUserName>
<CreateTime>1348831860</CreateTime>
<MsgType><![CDATA[text]]></MsgType>
<Content><![CDATA[this is a test]]></Content>
<MsgId>
<ToUserName><![CDATA[1]]></ToUserName>
<MsgId>
<ToUserName><![CDATA[2]]></ToUserName>
<ToUserName><![CDATA[3]]></ToUserName>
</MsgId>
<FromUserName><![CDATA[4]]></FromUserName>
</MsgId>
</xml>
下面是main方法以及兩個(gè)解析方法
方法說(shuō)明:
parseXML(Element e);這個(gè)是解析單個(gè)的,含有dom4j的基本用法。
dom4j下載:https://dom4j.github.io/
parseMutiXML(Element e);這個(gè)是解析含有多個(gè)節(jié)點(diǎn)的XML,加了一層判斷,即判斷節(jié)點(diǎn)還有沒(méi)有子節(jié)點(diǎn),如果沒(méi)有,直接打印出來(lái),反之重新遞歸使用方法,達(dá)到再解析的效果。
package xaiver.cn;
import java.io.File;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class CopyOfParseXml {
public static void main(String[] args) throws Exception {
// 這里直接解析xml,用到dom4j的包
// 1.讀取文件信息,三種方法讀取,1創(chuàng)建saxdom方法,2根據(jù)跟元素內(nèi)容讀取,3創(chuàng)建dom文件讀取
SAXReader reader = new SAXReader();
Document document = reader.read(new File(
"E:\\WorkSpace\\JavaSE\\Day01_HelloWorld\\src\\xmlparse.xml"));
Element element = document.getRootElement();
parseMutiXML(element);
}
@SuppressWarnings("unused")
private static void parseXML(Element element) {
// 得到名稱測(cè)試,測(cè)試結(jié)果為xml,需要獲取這個(gè)的根節(jié)點(diǎn)
String name = element.getName();
System.out.println(name);
// 根節(jié)點(diǎn)再獲取根節(jié)點(diǎn)
@SuppressWarnings("unchecked")
List<Element> list = element.elements();
// 再獲取根節(jié)點(diǎn)的List和里面的內(nèi)容,用增強(qiáng)for循環(huán)
for (Element e : list) {
System.out.println(e.getName() + "==>" + e.getTextTrim());
}
}
private static void parseMutiXML(Element root) {
@SuppressWarnings("unchecked")
List<Element> list = root.elements();
if (list.size()==0) {
System.out.println(root.getName()+"==>"+root.getTextTrim());
}else {
for (Element element:list) {
parseMutiXML(element);
}
}
}
}
執(zhí)行結(jié)果:
ToUserName==>toUser
FromUserName==>fromUser
CreateTime==>1348831860
MsgType==>text
Content==>this is a test
ToUserName==>1
ToUserName==>2
ToUserName==>3
FromUserName==>4
dom4j遞歸解析XML字符串所有子節(jié)點(diǎn)
/**
* dom4j遞歸解析所有子節(jié)點(diǎn)
*
* @param childElements
* @param mapEle
* @return
*/
public Map<String, Object> getElementsToString(String print) {
//解析返回的xml字符串,生成document對(duì)象
Document document = null;
Map<String,Object> mapEle = null;
try{
document = DocumentHelper.parseText(print);
//根節(jié)點(diǎn)
Element root = document.getRootElement();
//子節(jié)點(diǎn)
List<Element> childElements = root.elements();
mapEle = new HashMap<String, Object>();
//遍歷子節(jié)點(diǎn)
mapEle = getAllElements(childElements,mapEle);
}catch(DocumentException e){
// TODO Auto-generated catch block
e.printStackTrace();
}
return mapEle;
}
/**
* dom4j遞歸解析所有子節(jié)點(diǎn)
*
* @param childElements
* @param mapEle
* @return
*/
public static Map<String, Object> getAllElements(List<Element> childElements,Map<String,Object> mapEle) {
for (Element ele:childElements){
mapEle.put(ele.getName(), ele.getText());
if(ele.elements().size()>0){
mapEle = getAllElements(ele.elements(), mapEle);
}
}
return mapEle;
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java開(kāi)發(fā)ExecutorService監(jiān)控實(shí)現(xiàn)示例詳解
這篇文章主要為大家介紹了java開(kāi)發(fā)ExecutorService監(jiān)控實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
SpringBoot 改造成https訪問(wèn)的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot 改造成https訪問(wèn)的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10
SpringSecurity在單機(jī)環(huán)境下使用方法詳解
本文詳細(xì)介紹了SpringSecurity和SpringBoot的整合過(guò)程,包括配置用戶認(rèn)證、JSP頁(yè)面的使用、數(shù)據(jù)庫(kù)認(rèn)證以及授權(quán)功能的實(shí)現(xiàn),感興趣的朋友一起看看吧2025-02-02
springboot中如何通過(guò)cors協(xié)議解決跨域問(wèn)題
這篇文章主要介紹了springboot中通過(guò)cors協(xié)議解決跨域問(wèn)題,cors是一個(gè)w3c標(biāo)準(zhǔn),它允許瀏覽器(目前ie8以下還不能被支持)像我們不同源的服務(wù)器發(fā)出xmlHttpRequest請(qǐng)求,我們可以繼續(xù)使用ajax進(jìn)行請(qǐng)求訪問(wèn)。具體內(nèi)容詳情大家跟隨腳本之家小編一起學(xué)習(xí)吧2018-05-05
圖解Java?ReentrantLock的條件變量Condition機(jī)制
想必大家都使用過(guò)wait()和notify()這兩個(gè)方法把,他們主要用于多線程間的協(xié)同處理。而RenentrantLock也支持這樣條件變量的能力,而且相對(duì)于synchronized?更加強(qiáng)大,能夠支持多個(gè)條件變量,本文就來(lái)詳細(xì)說(shuō)說(shuō)2022-10-10

