91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

XML是什么

發布時間:2021-08-31 11:43:00 來源:億速云 閱讀:126 作者:chen 欄目:編程語言

這篇文章主要講解了“XML是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“XML是什么”吧!

目錄結構:

  1. 什么是XML

  2. 解析XML

    1. 解析XML的兩種方式

    2. 使用dom4j解析xml

      1. dom4j的部分API

      2. 打印一個XML文件的全部內容

    3. 在dom4j中應用XPath解析XML

      1. 相關的部分API

      2. XPath的路徑表達式

      3. 通配符

      4. 謂語

  3. 使用java寫一個XMl文件

    1. 將一個帶有書籍信息的List集合解析為XML文件

  4. Schema和DTD的區別


1 什么是XML

XML(eXtensible  markup language) 是一種可擴展的標記語言 ,即使可以自定義標簽的語言。

2 解析XML

2.1 解析的兩種方式

XML的解析分為兩種方式,分別是SAX和DOM。

DOM:(Document Object Model,就是文檔對象模型),是W3C組織推薦的處理XML的一種方式。使用該方式解析XML文檔,會把文檔中的所有元素,按照其出現的層次關系,在內存中構造出樹形結構。因此對內存的壓力大,解析熟讀慢,優點就是可以遍歷和修改節點的內容。

SAX:(Simple API for XML) 是一種XML解析的替代方法。相比較于DOM,解析速度更快,內存的壓力更小;缺點就是不能修改節點的內容。

2.2 使用dom4j解析XML

在使用dom4j解析XML之前需要導入相關的工具包,比如筆者的: dom4j-1.6.1.jar

2.2.1 dom4j的API

//創建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()                    獲取元素文本內容
  String elementText(String name)     獲取子元素文本內容
  Attribute attribute(String)         獲取元素的屬性
  String attributeValue(String name)  獲取元素的屬性值

Attribute
  String getName()                    獲取屬性的名字
  String getValue()                   獲取屬性的值

2.2.2 打印一個XML文件的全部內容

pricties.xml文件直接位于項目下

XML是什么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

XML是什么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) {//創建SAXReader對象SAXReader saxr=new SAXReader();
        Document  docu=null;try{//讀取指定的文件,相對于項目路徑docu=saxr.read(new File("pricties.xml"));//獲得元素的文件的根節點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()+">");//打印結束標記return;//退出當前層方法        }        //遞歸每一個子元素for(Element ele:elements){
            searchAllElement(ele);
        }
        System.out.println("</"+e.getName()+">");//打印結束標記    }

}

parseXML.xml

2.3 在dom4j中應用XPath解析XML

首先需要在dom4j基礎上引入相應的jar包,比如讀者的: jaxen-1.1-beta-6.jar

2.3.1 XPath的API

Document
  List<Node> selectNodes(String xpath)
  Node selectSingleNode(String xpath)

2.3.2 XPath的路徑表達式

2.3.2.1 XPath的路徑表達式規則

XML是什么

2.3.2.2 XPath的路徑表達式應用案例

XML是什么

2.3.3 通配符

2.3.3.1 通配符規則

XML是什么

2.3.3.2 通配符應用案例

XML是什么

2.3.4 謂語

2.3.4.1 謂語規則

謂語是用來查找某個特定的節點或是包含某個指定的值的節點
謂語被嵌在方括號中

2.3.4.2 謂語應用案例

XML是什么

3 java寫XML文件

3.1 將一個帶有書籍信息的List集合解析為XML文件

XML是什么XML是什么

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

XML是什么XML是什么

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) {//創建一個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);
        }        //創建一個文檔對象Document doc=DocumentHelper.createDocument();//創建一個根節點Element books=DocumentHelper.createElement("books");        //獲得書籍集合的大小int size=list_books.size();for(int i=0;i<size;i++){//創建一個book節點Element book=books.addElement("book");//創建一個name節點Element name=book.addElement("name");//創建一個author節點Element author=book.addElement("author");//創建一個price節點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());
        }//設置文檔根節點        doc.setRootElement(books);        try {//如果文件不存在,會自動創建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

4 Schema和DTD的區別

Schema是對XML文檔結構的定義和描述,其主要的作用是用來約束XML文件,并驗證XML文件有效性。DTD的作用是定義XML的合法構建模塊,它使用一系列的合法元素來定義文檔結構。它們之間的區別有下面幾點:

1、Schema本身也是XML文檔,DTD定義跟XML沒有什么關系,Schema在理解和實際應用有很多的好處。

2、DTD文檔的結構是“平鋪型”的,如果定義復雜的XML文檔,很難把握各元素之間的嵌套關系;Schema文檔結構性強,各元素之間的嵌套關系非常直觀。

3、DTD只能指定元素含有文本,不能定義元素文本的具體類型,如字符型、整型、日期型、自定義類型等。Schema在這方面比DTD強大。

4、Schema支持元素節點順序的描述,DTD沒有提供無序情況的描述,要定義無序必需窮舉排列的所有情況。Schema可以利用xs:all來表示無序的情況。

5、對命名空間的支持。DTD無法利用XML的命名空間,Schema很好滿足命名空間。并且,Schema還提供了include和import兩種引用命名空間的方法。

感謝各位的閱讀,以上就是“XML是什么”的內容了,經過本文的學習后,相信大家對XML是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

xml
AI

侯马市| 洞口县| 汝州市| 赞皇县| 宕昌县| 安新县| 鄂温| 延川县| 唐山市| 康平县| 拉孜县| 德格县| 汶上县| 北川| 工布江达县| 芦山县| 延寿县| 红桥区| 兰考县| 绵阳市| 孝义市| 开鲁县| 甘南县| 诸城市| 安多县| 于田县| 永宁县| 疏勒县| 从江县| 玉林市| 中山市| 高安市| 德清县| 门源| 合水县| 丁青县| 舞阳县| 商都县| 错那县| 朝阳市| 搜索|