用dom4j,解析xml 最好、最方便!
xml的解析工具有哪些,優缺點就不在這裡描述了。
目前推薦採用dom4j,所以這裡只是討論使用dom4j。
- //先加入dom4j.jar包
- import java.util.HashMap;
- import java.util.Iterator;
- import java.util.Map;
- import org.dom4j.Document;
- import org.dom4j.DocumentException;
- import org.dom4j.DocumentHelper;
- import org.dom4j.Element;
- /**
- * @description 解析xml字串
- * @author 無處不在
- * @Time 上午11:01:31
- */
- public class Test {
- public void readStringXml(String xml) {
- Document doc = null;
- try {
- // 讀取並解析XML文件
- // SAXReader就是一個管道,用一個流的方式,把xml檔案讀出來
- //
- // SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文件
- // Document document = reader.read(new File("User.hbm.xml"));
- // 下面的是通過解析xml字串的
- doc = DocumentHelper.parseText(xml); // 將字串轉為XML
- Element rootElt = doc.getRootElement(); // 獲取根節點
- System.out.println("根節點:" + rootElt.getName()); // 拿到根節點的名稱
- Iterator iter = rootElt.elementIterator("head"); // 獲取根節點下的子節點head
- // 遍歷head節點
- while (iter.hasNext()) {
- Element recordEle = (Element) iter.next();
- String title = recordEle.elementTextTrim("title"); // 拿到head節點下的子節點title值
- System.out.println("title:" + title);
- Iterator iters = recordEle.elementIterator("script"); // 獲取子節點head下的子節點script
- // 遍歷Header節點下的Response節點
- while (iters.hasNext()) {
- Element itemEle = (Element) iters.next();
- String username = itemEle.elementTextTrim("username"); // 拿到head下的子節點script下的位元組點username的值
- String password = itemEle.elementTextTrim("password");
- System.out.println("username:" + username);
- System.out.println("password:" + password);
- }
- }
- Iterator iterss = rootElt.elementIterator("body"); ///獲取根節點下的子節點body
- // 遍歷body節點
- while (iterss.hasNext()) {
- Element recordEless = (Element) iterss.next();
- String result = recordEless.elementTextTrim("result"); // 拿到body節點下的子節點result值
- System.out.println("result:" + result);
- Iterator itersElIterator = recordEless.elementIterator("form"); // 獲取子節點body下的子節點form
- // 遍歷Header節點下的Response節點
- while (itersElIterator.hasNext()) {
- Element itemEle = (Element) itersElIterator.next();
- String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子節點form下的位元組點banlce的值
- String subID = itemEle.elementTextTrim("subID");
- System.out.println("banlce:" + banlce);
- System.out.println("subID:" + subID);
- }
- }
- } catch (DocumentException e) {
- e.printStackTrace();
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- /**
- * @description 將xml字串轉換成map
- * @param xml
- * @return Map
- */
- public static Map readStringXmlOut(String xml) {
- Map map = new HashMap();
- Document doc = null;
- try {
- doc = DocumentHelper.parseText(xml); // 將字串轉為XML
- Element rootElt = doc.getRootElement(); // 獲取根節點
- System.out.println("根節點:" + rootElt.getName()); // 拿到根節點的名稱
- Iterator iter = rootElt.elementIterator("head"); // 獲取根節點下的子節點head
- // 遍歷head節點
- while (iter.hasNext()) {
- Element recordEle = (Element) iter.next();
- String title = recordEle.elementTextTrim("title"); // 拿到head節點下的子節點title值
- System.out.println("title:" + title);
- map.put("title", title);
- Iterator iters = recordEle.elementIterator("script"); // 獲取子節點head下的子節點script
- // 遍歷Header節點下的Response節點
- while (iters.hasNext()) {
- Element itemEle = (Element) iters.next();
- String username = itemEle.elementTextTrim("username"); // 拿到head下的子節點script下的位元組點username的值
- String password = itemEle.elementTextTrim("password");
- System.out.println("username:" + username);
- System.out.println("password:" + password);
- map.put("username", username);
- map.put("password", password);
- }
- }
- Iterator iterss = rootElt.elementIterator("body"); ///獲取根節點下的子節點body
- // 遍歷body節點
- while (iterss.hasNext()) {
- Element recordEless = (Element) iterss.next();
- String result = recordEless.elementTextTrim("result"); // 拿到body節點下的子節點result值
- System.out.println("result:" + result);
- Iterator itersElIterator = recordEless.elementIterator("form"); // 獲取子節點body下的子節點form
- // 遍歷Header節點下的Response節點
- while (itersElIterator.hasNext()) {
- Element itemEle = (Element) itersElIterator.next();
- String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子節點form下的位元組點banlce的值
- String subID = itemEle.elementTextTrim("subID");
- System.out.println("banlce:" + banlce);
- System.out.println("subID:" + subID);
- map.put("result", result);
- map.put("banlce", banlce);
- map.put("subID", subID);
- }
- }
- } catch (DocumentException e) {
- e.printStackTrace();
- } catch (Exception e) {
- e.printStackTrace();
- }
- return map;
- }
- public static void main(String[] args) {
- // 下面是需要解析的xml字串例子
- String xmlString = "<html>" + "<head>" + "<title>dom4j解析一個例子</title>"
- + "<script>" + "<username>yangrong</username>"
- + "<password>123456</password>" + "</script>" + "</head>"
- + "<body>" + "<result>0</result>" + "<form>"
- + "<banlce>1000</banlce>" + "<subID>36242519880716</subID>"
- + "</form>" + "</body>" + "</html>";
- /*
- * Test2 test = new Test2(); test.readStringXml(xmlString);
- */
- Map map = readStringXmlOut(xmlString);
- Iterator iters = map.keySet().iterator();
- while (iters.hasNext()) {
- String key = iters.next().toString(); // 拿到鍵
- String val = map.get(key).toString(); // 拿到值
- System.out.println(key + "=" + val);
- }
- }
- }
這裡遍歷了所有的子項。但是實際應用中,我們不需要遍歷所有的子節點。如果路徑到達三層,那麼解析起來就十分煩躁了。dom4j可以指定路徑,省去中間的遍歷。
- String xml ;//採用字串初始化Document。如果是普通檔案,可以採用上述程式碼中的方法。
- Document document = DocumentHelper.parseText(xml);
- List<Element> targetElements = document.selectNodes("//head/sub/target");//直接得到target的Element 的列表,省去中間的查詢,判斷。
dom4j還是很強大的,以後要多用用
相關文章
- java的XML解析(DOM4J技術)JavaXML
- DOM4J 解析 XML 之忽略轉義字元XML字元
- XML和Dom4jXML
- dom4j遍歷巢狀xml巢狀XML
- 【超好用API推薦】用dom4j建立XML檔案並寫入節點APIXML
- Xml解析XML
- Java解析XMLJavaXML
- go 解析xmlGoXML
- iOS – XML解析iOSXML
- python之XML解析PythonXML
- 175.XML解析XML
- C# XML解析C#XML
- Web 應用實時版本檢測,這麼做最方便Web
- Python XML解析之DOMPythonXML
- python XML 檔案解析PythonXML
- jdom解析xml檔案XML
- XML 檔案解析實踐 (DOM 解析)XML
- 最方便的ICON、PNG轉換工具
- XML解析-最快的方式SAXXML
- 使用DocumentBuilderFactory解析XML淺談UIXML
- XML DOM 解析器概述XML
- 使用 Java 解析XML檔案JavaXML
- ArkTS 中的 XML 解析與生成:應用開發實戰XML
- XQRCode 一個非常方便實用的二維碼掃描、解析、生成庫
- Tomcat 7 中 web 應用載入原理(二)web.xml 解析TomcatWebXML
- 推薦 OS X 下最方便實用的六款解壓縮軟體
- Python解析XML檔案生成HTMLPythonXMLHTML
- 搞懂 XML 解析,徒手造 WEB 框架XMLWeb框架
- 【spring原始碼系列】之【xml解析】Spring原始碼XML
- NPM酷庫051:xml2js,解析XML格式資料NPMXMLJS
- office哪個版本最好用 office最穩定實用的版本推薦
- 【Go學習筆記16】解析xmlGo筆記XML
- XML DOM 解析器錯誤概述XML
- 最好的PM與最壞的PM - PavelA
- 哪裡有最好最便宜的茶葉
- java使用jaxb解析XML(含根據xml自動生成實體類)JavaXML
- XML Web 服務技術解析:WSDL 與 SOAP 原理、應用案例一覽XMLWeb
- springMVC---配置檔案解析(web.xml)SpringMVCWebXML
- 基於 DOM 的 XML 檔案解析類XML