這篇文章主要講解了“XML是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“XML是什么”吧!
公司主營業(yè)務(wù):成都做網(wǎng)站、網(wǎng)站制作、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出和縣免費做網(wǎng)站回饋大家。
目錄結(jié)構(gòu):
什么是XML
解析XML
解析XML的兩種方式
使用dom4j解析xml
dom4j的部分API
打印一個XML文件的全部內(nèi)容
在dom4j中應(yīng)用XPath解析XML
相關(guān)的部分API
XPath的路徑表達式
通配符
謂語
使用java寫一個XMl文件
將一個帶有書籍信息的List集合解析為XML文件
Schema和DTD的區(qū)別
XML(eXtensible markup language) 是一種可擴展的標記語言 ,即使可以自定義標簽的語言。
XML的解析分為兩種方式,分別是SAX和DOM。
DOM:(Document Object Model,就是文檔對象模型),是W3C組織推薦的處理XML的一種方式。使用該方式解析XML文檔,會把文檔中的所有元素,按照其出現(xiàn)的層次關(guān)系,在內(nèi)存中構(gòu)造出樹形結(jié)構(gòu)。因此對內(nèi)存的壓力大,解析熟讀慢,優(yōu)點就是可以遍歷和修改節(jié)點的內(nèi)容。
SAX:(Simple API for XML) 是一種XML解析的替代方法。相比較于DOM,解析速度更快,內(nèi)存的壓力更小;缺點就是不能修改節(jié)點的內(nèi)容。
在使用dom4j解析XML之前需要導(dǎo)入相關(guān)的工具包,比如筆者的: dom4j-1.6.1.jar 包
//創(chuàng)建SAXReader,是dom4j包提供的解析器SAXReader reader=new SAXReader();//讀取指定的文件Document doc=reader.read(new File(filename)); Document Document getRootElement() 用于獲取根元素 Element Element element(String name) 獲取元素下指定名稱的子元素 List<Element> elements() 獲取元素下所有的子元素 String getName() 獲取元素名 String getText() 獲取元素文本內(nèi)容 String elementText(String name) 獲取子元素文本內(nèi)容 Attribute attribute(String) 獲取元素的屬性 String attributeValue(String name) 獲取元素的屬性值 Attribute String getName() 獲取屬性的名字 String getValue() 獲取屬性的值
pricties.xml文件直接位于項目下
<?xml version="1.0" encoding="utf-8" ?><books id="a"> <book id="b"><name id="c_1" name="c_2">三國演繹</name><author id="d_1" name="d_2" >羅貫中</author><price id="e">58.8</price> </book> <book id="f_1" name="f_2"><name id="g">水滸傳</name><author id="h">施耐庵</author><price id="i">49.8</price> </book> <book id="j_1" name="j_2"><name id="k">西游記</name><author id="l">吳承恩</author><price id="m">100.1</price><order>1</order> </book></books>
pricties.xml
import java.io.File;import java.util.List;import org.dom4j.Attribute;import org.dom4j.Document;import org.dom4j.Element;import org.dom4j.io.SAXReader;public class ParseXML {public static void main(String[] args) {//創(chuàng)建SAXReader對象SAXReader saxr=new SAXReader(); Document docu=null;try{//讀取指定的文件,相對于項目路徑docu=saxr.read(new File("pricties.xml"));//獲得元素的文件的根節(jié)點Element e=docu.getRootElement(); searchAllElement(e); }catch(Exception e){ e.printStackTrace(); } } public static void searchAllElement(Element e){//獲得當前元素下的所有子元素,并存儲到集合中List<Element> elements=e.elements(); System.out.print("<"+e.getName());//打印開始標記List<Attribute> atrs=e.attributes();//打印該標記下的所有屬性for(Attribute att:atrs){ System.out.print(" "+att.getName()+"=\""+att.getValue()+"\""); } System.out.println(">"); //如果集合的大小為0,表示該集合下沒有子元素了if(elements.size()==0){ System.out.println(e.getText());//打印文本信息System.out.println("</"+e.getName()+">");//打印結(jié)束標記return;//退出當前層方法 } //遞歸每一個子元素for(Element ele:elements){ searchAllElement(ele); } System.out.println("</"+e.getName()+">");//打印結(jié)束標記 } }
parseXML.xml
首先需要在dom4j基礎(chǔ)上引入相應(yīng)的jar包,比如讀者的: jaxen-1.1-beta-6.jar
Document List<Node> selectNodes(String xpath) Node selectSingleNode(String xpath)
謂語是用來查找某個特定的節(jié)點或是包含某個指定的值的節(jié)點
謂語被嵌在方括號中
package com.xdl.xml;public class Book {private String name;private String author;private String price;public Book() {super(); }public Book(String name, String author, String price) {super(); setName(name); setAuthor(author); setPrice(price); }/** * @return the name */public String getName() {return name; }/** * @param name the name to set */public void setName(String name) {this.name = name; }/** * @return the author */public String getAuthor() {return author; }/** * @param author the author to set */public void setAuthor(String author) {this.author = author; }/** * @return the price */public String getPrice() {return price; }/** * @param price the price to set */public void setPrice(String price) {this.price = price; } }
Book.java
package com.xdl.xml;import java.io.File;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.util.ArrayList;import java.util.List;import org.dom4j.Document;import org.dom4j.DocumentHelper;import org.dom4j.Element;import org.dom4j.io.XMLWriter;public class WriteXML {public static void main(String[] args) {//創(chuàng)建一個Book集合用于存儲書籍信息List<Book> list_books=new ArrayList<Book>();//插入書籍信息for(int i=0;i<6;i++){ Book book=new Book("jame"+i,"author"+i,""+i); list_books.add(book); } //創(chuàng)建一個文檔對象Document doc=DocumentHelper.createDocument();//創(chuàng)建一個根節(jié)點Element books=DocumentHelper.createElement("books"); //獲得書籍集合的大小int size=list_books.size();for(int i=0;i<size;i++){//創(chuàng)建一個book節(jié)點Element book=books.addElement("book");//創(chuàng)建一個name節(jié)點Element name=book.addElement("name");//創(chuàng)建一個author節(jié)點Element author=book.addElement("author");//創(chuàng)建一個price節(jié)點Element price=book.addElement("price"); name.setText(list_books.get(i).getName()); author.setText(list_books.get(i).getAuthor()); price.setText(list_books.get(i).getPrice()); }//設(shè)置文檔根節(jié)點 doc.setRootElement(books); try {//如果文件不存在,會自動創(chuàng)建FileOutputStream fos = new FileOutputStream(new File("books.xml")); XMLWriter xmlw = new XMLWriter(fos); xmlw.write(doc); xmlw.close(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }
WriteXML.java
Schema是對XML文檔結(jié)構(gòu)的定義和描述,其主要的作用是用來約束XML文件,并驗證XML文件有效性。DTD的作用是定義XML的合法構(gòu)建模塊,它使用一系列的合法元素來定義文檔結(jié)構(gòu)。它們之間的區(qū)別有下面幾點:
1、Schema本身也是XML文檔,DTD定義跟XML沒有什么關(guān)系,Schema在理解和實際應(yīng)用有很多的好處。
2、DTD文檔的結(jié)構(gòu)是“平鋪型”的,如果定義復(fù)雜的XML文檔,很難把握各元素之間的嵌套關(guān)系;Schema文檔結(jié)構(gòu)性強,各元素之間的嵌套關(guān)系非常直觀。
3、DTD只能指定元素含有文本,不能定義元素文本的具體類型,如字符型、整型、日期型、自定義類型等。Schema在這方面比DTD強大。
4、Schema支持元素節(jié)點順序的描述,DTD沒有提供無序情況的描述,要定義無序必需窮舉排列的所有情況。Schema可以利用xs:all來表示無序的情況。
5、對命名空間的支持。DTD無法利用XML的命名空間,Schema很好滿足命名空間。并且,Schema還提供了include和import兩種引用命名空間的方法。
感謝各位的閱讀,以上就是“XML是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對XML是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!
名稱欄目:XML是什么
URL地址:http://chinadenli.net/article8/jgghop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗、做網(wǎng)站、品牌網(wǎng)站建設(shè)、定制網(wǎng)站、建站公司、外貿(mào)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)