天天看點

XPath JAVA用法總結及代碼樣例

一、基本概念介紹

    xpath 是一門在 xml 文檔中查找資訊的語言, 可用來在 xml 文檔中對元素和屬性進行周遊。xpath 是 w3c xslt 标準的主要元素,并且 xquery 和 xpointer 同時被建構于 xpath 表達之上。是以,對 xpath 的了解是很多進階 xml 應用的基礎。

    xpath非常類似對資料庫操作的sql語言,或者說jquery,它可以友善開發者抓起文檔中需要的東西。(dom4j也支援xpath

   1.節點類型

    xpath中有七種結點類型:元素、屬性、文本、命名空間、處理指令、注釋以及文檔節點(或稱為根節點)。文檔中存在元素節點,屬性節點,根節點

   2.常用路徑表達式

表達式

描述 

節點名稱(nodename)

選取此節點的所有子節點

/

從根節點選取

//

從比對選擇的目前節點選擇文檔中的節點,而不考慮它們的位置

.

選取目前節點

..

選取目前節點的父節點

@

選取屬性

示例如下:

選取所有名為 lang 的屬性

 3.限定語

用來查找某個特定的節點或者包含某個指定的值的節點。以方括号括起

//book[price>35.00]

選擇所有book 元素,且其中的 price 元素的值須大于 35.00

/bookstore/book[1]

選取屬于 bookstore 子元素的第一個 book 元素。 

/bookstore/book[last()]

選取屬于 bookstore 子元素的最後一個 book 元素。 

/bookstore/book[last()-1]

選取屬于 bookstore 子元素的倒數第二個 book 元素。 

/bookstore/book[position()<3]

選取最前面的兩個屬于 bookstore 元素的子元素的 book 元素。 

//title[@lang]

選取所有擁有名為 lang 的屬性的 title 元素。 

//title[@lang='eng']

選取所有 title 元素,且這些元素擁有值為 eng 的 lang 屬性。 

/bookstore/book[price>35.00]

選取所有 bookstore 元素的 book 元素,且其中的 price 元素的值須大于 35.00。 

/bookstore/book[price>35.00]/title

選取所有 bookstore 元素中的 book 元素的 title 元素,且其中的 price 元素的值須大于 35.00。 

4 .通配符

通配符

*

比對任何元素節點 

<a href="http://my.oschina.net/u/138045" target="_blank">@*</a>

比對任何屬性節點 

node()

比對任何類型的節點 

|

選取若幹路徑  

使用示例

路徑表達式

結果 

/bookstore/*

選取 bookstore 元素的所有子節點 

//*

選取文檔中的所有元素 

//title[@*]

選取所有帶有屬性的 title 元素。 

//book/title | //book/price

選取所有 book 元素的 tilte 和 price 元素。 

//title | //price

選取所有文檔中的 title 和 price 元素。 

/bookstore/book/title | //price

選取所有屬于 bookstore 元素的 book 元素的 title 元素,以及文檔中所有的 price 元素

二、代碼示例

使用的xml文檔