您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“JavaSE XML解析技術如何使用”,內容詳細,步驟清晰,細節處理妥當,希望這篇“JavaSE XML解析技術如何使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
XML的數據作用是什么? 最終需要怎樣處理?
作用: 存儲數據、做配置信息、進行數據傳輸。
最終需要被程序進行讀取,解析里面的信息。
XML解析就是使用程序讀取XML中的數據:
有兩種解析方式:
SAX解析
DOM解析(我們重點學習DOM解析)
DOM常見的解析工具:
名稱 | 說明 |
---|---|
JAXP | SUN公司提供的一套XML的解析的API |
JDOM | JDOM是一個開源項目,它基于樹型結構,利用純JAVA的技術對XML文檔實現解析、生成、序列化以及多種操作。 |
dom4j | 是JDOM的升級品,用來讀寫XML文件的。具有性能優異、功能強大和極其易使用的特點,它的性能超過sun公司官方的dom 技術,同時它也是一個開放源代碼的軟件,Hibernate也用它來讀寫配置文件。 |
jsoup | 功能強大DOM方式的XML解析開發包,尤其對HTML解析更加方便 |
DOM解析, 解析文檔對象模型如下:
其中:
Document對象: 代表整個xml文檔對象
Element對象: 代表元素(標簽), 例如上面student, name, age等等
Attribute對象: 代表屬性, 例如上面的id
Text對象: 代表文本內容, 例如上面張三, 李四等等
Element、Attribute、Text對象都是一個Node節點, 實現了Node接口
Dom4j下載及導入:
下載Dom4j框架,官網下載。
在項目中創建一個文件夾:lib
將dom4j-2.1.1.jar文件復制到 lib 文件夾
在jar文件上點右鍵,選擇 Add as Library -> 點擊OK
在類中導包使用
案例:
使用Dom4J把一個XML文件的數據進行解析
Dom4j解析XML-得到Document對象:
SAXReader類
構造器/方法 | 說明 |
---|---|
SAXReader() | 創建Dom4J的解析器對象 |
read(String url) | 加載XML文件成為Document對象 |
Document類
方法名 | 說明 |
---|---|
getRootElement() | 獲得根元素對象 |
實現步驟:
步驟一: 準備一個XML文件
<?xml version="1.0" encoding="UTF-8"?> <books> <book id="0001" desc="我是第一本書"> <name> JavaWeb開發教程</name> <author> 張孝祥 </author> <sale>100.00元</sale> </book> <book id="0002"> <name>三國演義</name> <author>羅貫中</author> <sale>100.00元</sale> </book> <sql> select * from user where age >= 18 </sql> </books>
步驟二: 創建一個Domj解析器對象, 加載XML文件稱為Document對象
步驟三: 獲取根元素對象
public static void main(String[] args) throws Exception { // 1. 創建一個Dom4j解析對象 SAXReader saxReader = new SAXReader(); // 把XML文件加載到內存中成為一個Document對象 // Document document = saxReader.read(new File("/Users/chenyq/Documents/learn_Java/code/JavaSE/xml-app/src/books.xml")); InputStream is = Dom4jDemo.class.getResourceAsStream("/books.xml"); Document document = saxReader.read(is); // 2. 獲取根元素對象 Element root = document.getRootElement(); }
Dom4j解析XML的元素、屬性、文本的方法如下:
方法名 | 說明 |
---|---|
List<Element> elements() | 得到當前元素下所有子元素 |
List<Element> elements(String name) | 得到當前元素下指定名字的子元素返回集合 |
Element element(String name) | 得到當前元素下指定名字的子元素,如果有很多名字相同的返回第一個 |
String getName() | 得到元素名字 |
String attributeValue(String name) | 通過屬性名直接得到屬性值 |
String elementText(子元素名) | 得到指定名稱的子元素的文本 |
String getText() | 得到文本 |
演示代碼:
public static void main(String[] args) throws Exception { SAXReader saxReader = new SAXReader(); InputStream is = Dom4jDemo.class.getResourceAsStream("/books.xml"); Document document = saxReader.read(is); Element root = document.getRootElement(); // 獲取根元素下的所有子元素 List<Element> allsonEls = root.elements(); // 打印子元素的名稱 for (Element allsonEl : allsonEls) { System.out.println(allsonEl.getName()); // book book sql } // 獲取當前元素下指定名字的子元素返回的集合 List<Element> bookEls = root.elements("book"); for (Element bookEl : bookEls) { System.out.println(bookEl.getName()); // book book } // 得到當前元素下指定名字的子元素,如果有很多名字相同的返回第一個 Element bookEL = root.element("book"); System.out.println(bookEL.getName()); // book // 通過屬性名獲取屬性值 System.out.println(bookEL.attributeValue("id")); // 0001 // 得到指定名稱的子元素的文本 System.out.println(bookEL.elementText("name")); // JavaWeb開發教程 // 得到文本 System.out.println(bookEL.element("sale").getText()); // 100.00元 }
需求:
利用Dom4J的知識,將Contact.xml文件中的聯系人數據封裝成List集合,其中每個元素是實體類Contact。打印輸出 List 中的每個元素。
Contact.xml文件內容如下:
<?xml version="1.0" encoding="UTF-8"?> <contactList> <contact id="1"> <name>潘金蓮</name> <gender>女</gender> <email>panpan@itcast.cn</email> </contact> <contact id="2"> <name>武松</name> <gender>男</gender> <email>wusong@itcast.cn</email> </contact> <contact id="3"> <name>武大狼</name> <gender>男</gender> <email>wuda@itcast.cn</email> </contact> <user> </user> </contactList>
要求打印結果如下圖所示:
實現步驟如下:
步驟一: 創建一個Contact類
public class Contact { private int id; private String name; private char gender; private String email; public Contact() {} public Contact(int id, String name, char gender, String email) { this.id = id; this.name = name; this.gender = gender; this.email = email; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public char getGender() { return gender; } public void setGender(char gender) { this.gender = gender; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } @Override public String toString() { return "Contact{" + "id=" + id + ", name='" + name + '\'' + ", gender=" + gender + ", email='" + email + '\'' + '}'; } }
步驟二: 在主類中進行下面操作
創建Dom4j解析器, 加載XML文件為Document對象
獲取根元素對象
獲取所有的contact元素
準備一個集合裝contact對象, 遍歷所有的contact元素, 獲取類的成員變量的值添加到List集合中
打印結果
Contact{id=1, name='潘金蓮', gender=女, email='panpan@itcast.cn'}
Contact{id=2, name='武松', gender=男, email='wusong@itcast.cn'}
Contact{id=3, name='武大狼', gender=男, email='wuda@itcast.cn'}
讀到這里,這篇“JavaSE XML解析技術如何使用”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。