一、基本概念介紹
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文檔