java怎麼解析相同xml節點(java解析xml獲取節點的屬性)

本文目錄一覽:

Java怎麼解析相同XML節點?求大神指導一下。

package com.sun;

import java.io.File;

import java.util.List;

import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.Element;

import org.dom4j.io.SAXReader;

public class Dom4jTest {

public void fun() {

File file = new File(“d:\\toRead.xml”);

//用SAXReader來加載xml文件

SAXReader saxReader = new SAXReader();

//獲取xml文件的Document對象

Document document = saxReader.read(file);

//獲得Document對象的根節點,就是UFIDA-FAHON-WebService節點

Element rootElement = document.getRootElement();

//list 裡面裝的就是你的xml文件根節點的所有子節點,就是所有的U8ArrivalVouch節點

ListElement list = rootElement.elements();

//增強for循環來遍歷所有的U8ArrivalVouch節點

for (Element element : list) {

//待處理內容,可以繼續用elements()方法繼續獲得所有的子節點

;

}

}

}

//你的xml文件的最後應該是/UFIDA-FAHON-WebService才對,這才符合xml規範

UFIDA-FAHON-WebService

……

/UFIDA-FAHON-WebService

java xml中怎麼獲取相同節點名元素 如:

java中獲取xml節點元素值 根據不同的處理xml方式不同而不同。

java中解析xml的方式:大體可以使用以下四種

————————————————————

DOM(Document Object Model)

為 XML 文檔的已解析版本定義了一組接口。解析器讀入整個文檔,

然後構建一個駐留內存的樹結構,然後代碼就可以使用 DOM 接口來操作這個樹結構。

優點:整個文檔樹在內存中,便於操作;支持刪除、修改、重新排列等多種功能;

缺點:將整個文檔調入內存(包括無用的節點),浪費時間和空間;

使用場合:一旦解析了文檔還需多次訪問這些數據;硬件資源充足(內存、CPU)

SAX(Simple API for XML)

為解決DOM的問題,出現了SAX。SAX ,事件驅動。

當解析器發現元素開始、元素結束、文本、文檔的開始或結束等時,發送事件,

程序員編寫響應這些事件的代碼,保存數據。優點:不用事先調入整個文檔,佔用資源少;

SAX解析器代碼比DOM解析器代碼小,適於Applet,下載。

缺點:不是持久的;事件過後,若沒保存數據,那麼數據就丟了;無狀態性;

從事件中只能得到文本,但不知該文本屬於哪個元素;

使用場合:Applet;只需XML文檔的少量內容,很少回頭訪問;機器內存少;

DOM4J

DOM4J 是一個非常非常優秀的Java XML API,具有性能優異、功能強大和極端易用使用的特點,

同時它也是一個開放源代碼的軟件。如今你可以看到越來越多的 Java 軟件都在使用 DOM4J 來讀寫 XML,

特別值得一提的是連 Sun 的 JAXM 也在用 DOM4J

JDOM

為減少DOM、SAX的編碼量,出現了JDOM;優點:20-80原則,極大減少了代碼量。

使用場合:要實現的功能簡單,如解析、創建等,但在底層,JDOM還是使用SAX(最常用)、DOM、Xanan文檔。

——————————

參考代碼

dom4j

——————————

import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.DocumentHelper;

import org.dom4j.Element;

import org.dom4j.io.SAXReader;

import org.dom4j.io.XMLWriter;

———————————————

File f = new File(“students.xml”);

SAXReader reader = new SAXReader();

Document doc = reader.read(f);

Element root = doc.getRootElement();

for (Iterator iter = root.elementIterator(); iter.hasNext();) {

Element element = (Element) iter.next();

// System.out.println(element.attributeValue(“email”));

String ids=element.elementText(“stuId”);

System.out.println(ids);

String names=element.elementText(“stuName”);

System.out.println(names);

String ages=element.elementText(“age”);

System.out.println(ages);

}

————————————

dom 方式

—————

import javax.xml.parsers.*;

import javax.xml.transform.*;

import javax.xml.transform.dom.DOMSource;

import javax.xml.transform.stream.StreamResult;

————————

DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();

// 允許名字空間

// factory.setNamespaceAware(true);

// 允許驗證

// factory.setValidating(true);

// 獲得DocumentBuilder的一個實例

DocumentBuilder builder = null;

try {

builder = factory.newDocumentBuilder();

} catch (ParserConfigurationException pce) {

System.err.println(pce);

// 出異常時輸出異常信息,然後退出,下同

System.exit(1);

}

Document doc = null;

// 解析文檔,並獲得一個Document實例。

try {

try {

// InputStream is=new FileInputStream(“students.xml”);

doc = builder.parse(“students.xml”);

// doc = builder.parse(is);

} catch (SAXException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

} catch (DOMException dom) {

System.err.println(dom.getMessage());

System.exit(1);

} catch (IOException ioe) {

System.err.println(ioe);

// System.exit(1);

}

for (int i = 0; i nlStudent.getLength(); i++) {

Element elmtStudent = (Element) nlStudent.item(i);

String email = elmtStudent.getAttribute(“email”);

System.out.println(email);

NodeList ids = elmtStudent.getElementsByTagName(“stuId”);

Element id = (Element)ids.item(0);

Node tId = id.getFirstChild();

System.out.println(tId.getNodeValue());

NodeList names = elmtStudent.getElementsByTagName(“stuName”);

Element e = (Element)names.item(0);

Node tName = e.getFirstChild();

System.out.println(tName.getNodeValue());

}

java中xml出現重複標籤節點,整么解決啊?

Element list= eb.element(“list”);

Iterator? records= out.elementIterator(“record”);

Element record;

while (records.hasNext()) {

record = records.next();

String xmlText = rd.element(“customerId”).getText();

………

}

用的是dom4j,如果你用的其他的插件或沒有這個jar包是不能用的

java 如何循環讀取xml下相同子節點

Reader reader = new InputStreamReader(con

.getInputStream());

SAXReader sax = new SAXReader();

// sax.setEncoding(“GBK”);

Document document = sax.read(reader);

document.setXMLEncoding(“GBK”);

Element root = document.getRootElement();

// Document doc = reader.read(read);

// Element root = doc.getRootElement();

readNode(root, “”);

public static void readNode(Element root, String prefix) {

if (root == null) return;

// 獲取屬性

List attrs = root.attributes();

if (attrs != null attrs.size() 0) {

System.err.print(prefix);

for (Attribute attr : attrs) {

System.err.print(attr.getValue() + ” “);

}

System.err.println();

}

// 獲取他的子節點

List childNodes = root.elements();

prefix += “\t”;

for (Element e : childNodes) {

//輸出內容

System.err.println(e.getName()+”:”+e.getData());

readNode(e, prefix);

}

}

java解析xml有幾種方法

SAX, DOM, jdom , dom4j四種

1、DOM(JAXP Crimson解析器)

DOM是用與平台和語言無關的方式表示XML文檔的官方W3C標準。DOM是以層次結構組織的節點或信息片斷的集合。

這個層次結構允許開發人員在樹中尋找特定信息。分析該結構通常需要加載整個文檔和構造層次結構,然後才能做任何工作。

由於它是基於信息層次的,因而DOM被認為是基於樹或基於對象的。DOM以及廣義的基於樹的處理具有幾個優點。

首先,由於樹在內存中是持久的,因此可以修改它以便應用程序能對數據和結構作出更改。

它還可以在任何時候在樹中上下導航,而不是像SAX那樣是一次性的處理。DOM使用起來也要簡單得多。

2、SAX

SAX處理的優點非常類似於流媒體的優點。分析能夠立即開始,而不是等待所有的數據被處理。而且,由於應用程序只是在讀取數據時檢查數據,因此不需要將數據存儲在內存中。這對於大型文檔來說是個巨大的優點。事實上,應用程序甚至不必解析整個文檔;它可以在某個條件得到滿足時停止解析。一般來說,SAX還比它的替代者DOM快許多。 選擇DOM還是選擇SAX? 對於需要自己編寫代碼來處理XML文檔的開發人員來說,選擇DOM還是SAX解析模型是一個非常重要的設計決策。 DOM採用建立樹形結構的方式訪問XML文檔,而SAX採用的事件模型。

DOM解析器把XML文檔轉化為一個包含其內容的樹,並可以對樹進行遍歷。用DOM解析模型的優點是編程容易,開發人員只需要調用建樹的指令,然後利用navigation APIs訪問所需的樹節點來完成任務。可以很容易的添加和修改樹中的元素。然而由於使用DOM解析器的時候需要處理整個XML文檔,所以對性能和內存的要求比較高,尤其是遇到很大的XML文件的時候。由於它的遍歷能力,DOM解析器常用於XML文檔需要頻繁的改變的服務中。

SAX解析器採用了基於事件的模型,它在解析XML文檔的時候可以觸發一系列的事件,當發現給定的tag的時候,它可以激活一個回調方法,

告訴該方法制定的標籤已經找到。SAX對內存的要求通常會比較低,因為它讓開發人員自己來決定所要處理的tag。

特別是當開發人員只需要處理文檔中所包含的部分數據時,SAX這種擴展能力得到了更好的體現。但用SAX解析器的時候編碼工作會比較困難,

而且很難同時訪問同一個文檔中的多處不同數據。

3、JDOM

JDOM的目的是成為Java特定文檔模型,它簡化與XML的交互並且比使用DOM實現更快。由於是第一個Java特定模型,JDOM一直得到大力推廣和促進。

正在考慮通過“Java規範請求JSR-102”將它最終用作“Java標準擴展”。從2000年初就已經開始了JDOM開發。

JDOM與DOM主要有兩方面不同。首先,JDOM僅使用具體類而不使用接口。這在某些方面簡化了API,但是也限制了靈活性。

第二,API大量使用了Collections類,簡化了那些已經熟悉這些類的Java開發者的使用。

JDOM文檔聲明其目的是“使用20%(或更少)的精力解決80%(或更多)Java/XML問題”(根據學習曲線假定為20%)。JDOM對於大多數Java/XML應用程序來說當然是有用的,並且大多數開發者發現API比DOM容易理解得多。JDOM還包括對程序行為的相當廣泛檢查以防止用戶做任何在XML中無意義的事。

然而,它仍需要您充分理解XML以便做一些超出基本的工作(或者甚至理解某些情況下的錯誤)。這也許是比學習DOM或JDOM接口都更有意義的工作。

JDOM自身不包含解析器。它通常使用SAX2解析器來解析和驗證輸入XML文檔(儘管它還可以將以前構造的DOM表示作為輸入)。

它包含一些轉換器以將JDOM表示輸出成SAX2事件流、DOM模型或XML文本文檔。JDOM是在Apache許可證變體下發布的開放源碼。

4、DOM4J

雖然DOM4J代表了完全獨立的開發結果,但最初,它是JDOM的一種智能分支。它合併了許多超出基本XML文檔表示的功能,包括集成的XPath支持、XML Schema支持以及用於大文檔或流化文檔的基於事件的處理。它還提供了構建文檔表示的選項,它通過DOM4J API和標準DOM接口具有並行訪問功能。從2000下半年開始,它就一直處於開發之中。

為支持所有這些功能,DOM4J使用接口和抽象基本類方法。DOM4J大量使用了API中的Collections類,但是在許多情況下,它還提供一些替代方法以允許更好的性能或更直接的編碼方法。直接好處是,雖然DOM4J付出了更複雜的API的代價,但是它提供了比JDOM大得多的靈活性。在添加靈活性、XPath集成和對大文檔處理的目標時,DOM4J的目標與JDOM是一樣的:針對Java開發者的易用性和直觀操作。它還致力於成為比JDOM更完整的解決方案,實現在本質上處理所有Java/XML問題的目標。在完成該目標時,它比JDOM更少強調防止不正確的應用程序行為。

DOM4J是一個非常非常優秀的Java XML API,具有性能優異、功能強大和極端易用使用的特點,同時它也是一個開放源代碼的軟件。如今你可以看到越來越多的Java軟件都在使用DOM4J來讀寫XML,特別值得一提的是連Sun的JAXM也在用DOM4J。

比較

1、DOM4J性能最好,連Sun的JAXM也在用DOM4J。目前許多開源項目中大量採用DOM4J,例如大名鼎鼎的Hibernate也用DOM4J來讀取XML配置文件。如果不考慮可移植性,那就採用DOM4J。

2、JDOM和DOM在性能測試時表現不佳,在測試10M文檔時內存溢出。在小文檔情況下還值得考慮使用DOM和JDOM。雖然JDOM的開發者已經說明他們期望在正式發行版前專註性能問題,但是從性能觀點來看,它確實沒有值得推薦之處。另外,DOM仍是一個非常好的選擇。DOM實現廣泛應用於多種編程語言。它還是許多其它與XML相關的標準的基礎,因為它正式獲得W3C推薦(與基於非標準的Java模型相對),所以在某些類型的項目中可能也需要它(如在JavaScript中使用DOM)。

3、SAX表現較好,這要依賴於它特定的解析方式-事件驅動。一個SAX檢測即將到來的XML流,但並沒有載入到內存(當然當XML流被讀入時,會有部分文檔暫時隱藏在內存中)

網頁鏈接

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/245386.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 13:08
下一篇 2024-12-12 13:08

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論