Java中解析XML的方式有哪些
java解析XML的方式有使用DOM解析透過DOM物件以樹狀結構連接在一起;使用SAX 解析它是遇到不同元素時會逐行解析;使用StAX解析會從XML中提取所需的資料
XML是一種通用的資料交換格式,它的平台無關性、語言無關性、系統無關性、給資料整合與互動帶來了極大的方便。接下來將會在文章中為大家具體介紹在Java中解析XML的方式,具有一定的參考作用,希望對大家有所幫助
##【推薦課程:XML教學】
#使用DOM解析##DOM解析器主要用於在記憶體中使用XML作為物件圖(樹狀結構) 也就是文件物件模型(DOM)。首先解析器遍歷輸入XML檔案並建立與XML檔案中的節點相對應的DOM物件。這些DOM物件以樹狀結構連結在一起。一旦解析器完成了解析過程,就會從中得到這個類似樹的DOM物件結構。
範例:在所有程式碼範例中解析xml內容
public class DOMParserDemo { public static void main(String[] args) throws Exception { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document document = builder.parse( ClassLoader.getSystemResourceAsStream("xml/employee.xml")); List<Employee> empList = new ArrayList<>(); NodeList nodeList = document.getDocumentElement().getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node instanceof Element) { Employee emp = new Employee(); emp.id = node.getAttributes(). getNamedItem("id").getNodeValue(); NodeList childNodes = node.getChildNodes(); for (int j = 0; j < childNodes.getLength(); j++) { Node cNode = childNodes.item(j); if (cNode instanceof Element) { String content = cNode.getLastChild(). getTextContent().trim(); switch (cNode.getNodeName()) { case "firstName": emp.firstName = content; break; case "lastName": emp.lastName = content; break; case "location": emp.location = content; break; } } } empList.add(emp); } } for (Employee emp : empList) { System.out.println(emp); } } } class Employee{ String id; String firstName; String lastName; String location; @Override public String toString() { return firstName+" "+lastName+"("+id+")"+location; } }輸出結果為:
Rakesh Mishra(111)Bangalore John Davis(112)Chennai Rajesh Sharma(113)Pune
使用SAX 解析
SAX Parser與DOM解析器的不同之處在於SAX解析器不會將完整的XML載入到記憶體中,而是在遇到不同的元素時,它逐行解析XML,c觸發不同的事件,例如:開啟標記,結束標記,字元數據,評論等。
使用SAX Parser解析XML的程式碼如下:
import java.util.ArrayList; import java.util.List; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; public class SAXParserDemo { public static void main(String[] args) throws Exception { SAXParserFactory parserFactor = SAXParserFactory.newInstance(); SAXParser parser = parserFactor.newSAXParser(); SAXHandler handler = new SAXHandler(); parser.parse(ClassLoader.getSystemResourceAsStream("xml/employee.xml"), handler); for ( Employee emp : handler.empList){ System.out.println(emp); } } } class SAXHandler extends DefaultHandler { List<Employee> empList = new ArrayList<>(); Employee emp = null; String content = null; @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { switch(qName){ case "employee": emp = new Employee(); emp.id = attributes.getValue("id"); break; } } @Override public void endElement(String uri, String localName, String qName) throws SAXException { switch(qName){ case "employee": empList.add(emp); break; case "firstName": emp.firstName = content; break; case "lastName": emp.lastName = content; break; case "location": emp.location = content; break; } } @Override public void characters(char[] ch, int start, int length) throws SAXException { content = String.copyValueOf(ch, start, length).trim(); } } class Employee { String id; String firstName; String lastName; String location; @Override public String toString() { return firstName + " " + lastName + "(" + id + ")" + location; } }輸出結果為:
Rakesh Mishra(111)Bangalore
John Davis(112)Chennai
Rajesh Sharma(113)Pune
#StAX用於XML的Streaming API,而StAX Parser與SA的不同之處在於SAX Parser。 StAX解析器也是一種與SAX解析器也是有所不同的
SAX Parser會推送數據,但StAX解析器會從XML中提取所需的數據。 StAX解析器將遊標維持在文件中的目前位置,允許提取遊標處可用的內容,而SAX解析器在遇到某些資料時發出事件。
XMLInputFactory和XMLStreamReader是兩個可用來載入XML檔案的類別。當我們使用XMLStreamReader讀取XML檔案時,事件會以整數值的形式生成,然後將這些事件與XMLStreamConstants中的常數進行比較。以下程式碼顯示如何使用StAX解析器解析XML:
import java.util.ArrayList; import java.util.List; import javax.xml.stream.XMLInputFactory; import javax.xml.stream.XMLStreamConstants; import javax.xml.stream.XMLStreamException; import javax.xml.stream.XMLStreamReader; public class StaxParserDemo { public static void main(String[] args) throws XMLStreamException { List<Employee> empList = null; Employee currEmp = null; String tagContent = null; XMLInputFactory factory = XMLInputFactory.newInstance(); XMLStreamReader reader = factory.createXMLStreamReader( ClassLoader.getSystemResourceAsStream("xml/employee.xml")); while(reader.hasNext()){ int event = reader.next(); switch(event){ case XMLStreamConstants.START_ELEMENT: if ("employee".equals(reader.getLocalName())){ currEmp = new Employee(); currEmp.id = reader.getAttributeValue(0); } if("employees".equals(reader.getLocalName())){ empList = new ArrayList<>(); } break; case XMLStreamConstants.CHARACTERS: tagContent = reader.getText().trim(); break; case XMLStreamConstants.END_ELEMENT: switch(reader.getLocalName()){ case "employee": empList.add(currEmp); break; case "firstName": currEmp.firstName = tagContent; break; case "lastName": currEmp.lastName = tagContent; break; case "location": currEmp.location = tagContent; break; } break; case XMLStreamConstants.START_DOCUMENT: empList = new ArrayList<>(); break; } } for ( Employee emp : empList){ System.out.println(emp); } } } class Employee{ String id; String firstName; String lastName; String location; @Override public String toString(){ return firstName+" "+lastName+"("+id+") "+location; } }輸出結果為:
Rakesh Mishra(111) Bangalore John Davis(112) Chennai Rajesh Sharma(113) Pune
總結:以上就是這篇文章的全部內容了,希望對大家有幫助
以上是Java中解析XML的方式有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Stock Market GPT
人工智慧支援投資研究,做出更明智的決策

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

UseFile.createNewFile()tocreateafileonlyifitdoesn’texist,avoidingoverwriting;2.PreferFiles.createFile()fromNIO.2formodern,safefilecreationthatfailsifthefileexists;3.UseFileWriterorPrintWriterwhencreatingandimmediatelywritingcontent,withFileWriterover

最直接的方法是回憶保存位置,通常在桌面、文檔、下載等文件夾;若找不到,可使用系統搜索功能。文件“失踪”多因保存路徑未留意、名稱記憶偏差、文件被隱藏或云同步問題。高效管理建議:按項目、時間、類型分類,善用快速訪問,定期清理歸檔,並規範命名。 Windows通過文件資源管理器和任務欄搜索查找,macOS則依賴訪達和聚焦搜索(Spotlight),後者更智能高效。掌握工具並養成良好習慣是關鍵。

使用-cp參數可將JAR加入類路徑,使JVM能加載其內類與資源,如java-cplibrary.jarcom.example.Main,支持多JAR用分號或冒號分隔,也可通過CLASSPATH環境變量或MANIFEST.MF配置。

使用implements關鍵字實現接口,類需提供接口中所有方法的具體實現,支持多接口時用逗號分隔,確保方法為public,Java8後默認和靜態方法無需重寫。

首先檢查網絡連接是否正常,若其他網站也無法打開則問題在網絡;1.清除瀏覽器緩存和Cookies,進入Chrome設置選擇清除瀏覽數據;2.關閉擴展程序,可通過無痕模式測試是否因插件衝突導致;3.檢查並關閉代理或VPN設置,避免網絡連接被攔截;4.重置Chrome網絡設置,恢復默認配置;5.更新或重裝Chrome至最新版本以解決兼容性問題;6.使用其他瀏覽器對比測試,確認問題是否僅限Chrome;根據錯誤提示如ERR_CONNECTION_TIMED_OUT或ERR_SSL_PROTOCOL_ER

Javagenericsprovidecompile-timetypesafetyandeliminatecastingbyallowingtypeparametersonclasses,interfaces,andmethods;wildcards(?,?extendsType,?superType)handleunknowntypeswithflexibility.1.UseunboundedwildcardwhentypeisirrelevantandonlyreadingasObject

使用datetime.strptime()方法可將字符串轉換為datetime對象,需確保格式符與字符串完全匹配;2.常見格式符包括%Y(四位年)、%m(月)、%d(日)、%H(時)、%M(分)、%S(秒)等;3.對於帶AM/PM的時間使用%I和%p,對於ISO格式可直接用datetime.fromisoformat();4.若格式不匹配會拋出ValueError,處理多種格式時推薦使用dateutil.parser.parse()自動識別。正確使用這些方法能高效完成字符串到datetime對象

實時系統需確定性響應,因正確性依賴結果交付時間;硬實時系統要求嚴格截止期限,錯過將致災難,軟實時則允許偶爾延遲;非確定性因素如調度、中斷、緩存、內存管理等影響時序;構建方案包括選用RTOS、WCET分析、資源管理、硬件優化及嚴格測試。
