語法
選取節點XPath使用路徑表達式在XML文檔中選取節點。節點是通過沿着路徑或者step來選取的。
下面列出了最有用的路徑表達式:
在下面的表格中,我們已列出了一些路徑表達式以及表達式的結果:
表達式
XPath使用路徑表達式來選取XML文檔中的節點或者節點集。這些路徑表達式和我們在常規的電腦文件系統中看到的表達式非常相似。路徑表達式是從一個XML節點(當前的上下文節點)到另一個節點、或一組節點的書面步驟順序。這些步驟以“/”字符分開,每一步有三個構成成分:
1、軸描述(用最直接的方式接近目标節點)
2、節點測試(用于篩選節點位置和名稱)
3、節點描述(用于篩選節點的屬性和子節點特征)
一般情況下,我們使用簡寫後的語法。雖然完整的軸描述是一種更加貼近人類語言,利用自然語言的單詞和語法來書寫的描述方式,但是相比之下也更加啰嗦。
運算符
下面列出了可用在XPath表達式中的運算符:
标準函數
XPath含有超過100個内建的函數。這些函數用于字符串值、數值,日期和時間比較、節點和QName處理、序列處理、邏輯值等等。
使用
XPath是XSLT标準中的主要元素。如果沒有XPath方面的知識,您就無法創建XSLT文檔。
XQuery和XPointer均構建于XPath表達式之上。XQuery1.0和XPath2.0共享相同的數據模型,并支持相同的函數和運算符。
您可以在我們的《XQuery教程》中閱讀更多有關XQuery的知識。
标準
XPath于1999年11月16日成為W3C标準。
XPath被設計供XSLT、XPointer以及其他XML解析軟件使用。
軸定義
軸可定義相對于當前節點的節點集。
每個步均根據當前節點集之中的節點來進行計算。
步(step)包括:
軸(axis)
定義所選節點與當前節點之間的樹關系
節點測試(node-test)
識别某個軸内部的節點
零個或者更多謂語(predicate)
更深入地提煉所選的節點集
步的語法:
軸名稱::節點測試[謂語]
實例
節點關系
節點(Node)是XPath的術語。
在XPath中,有七種類型的節點:元素、屬性、文本、命名空間、處理指令、注釋以及文檔(根)節點。XML文檔是被作為節點樹來對待的。樹的根被稱為文檔節點或者根節點。
存取函數
名稱、說明
fn:node-name(node)返回參數節點的節點名稱。
fn:nilled(node)返回是否拒絕參數節點的布爾值。
fn:data(item.item,...)接受項目序列,并返回原子值序列。
fn:base-uri()
fn:base-uri(node)
返回當前節點或指定節點的base-uri屬性的值。
fn:document-uri(node)返回指定節點的document-uri屬性的值。
語言升級
在W3C建議下,XPath1.0于1999年11月16日發表。XPath2.0正在W3C審核過程的最終階段。XPath2.0表達了XPath語言在大小與能力上顯著的增加。
最值得一提的改變是XPath2.0有了更豐富的型别系統;XPath2.0支持不可分割型态,如在XMLS chema内建型态定義一樣,并且也可自綱要(schema)導入用戶自定型别。每個值都是一個序列(一個單一不可分割值或節點都被視為長度一的序列)。XPath1.0節點組被節點序列取代,它可以是任何順序。
為了支持更豐富的型别組,XPath2.0提供相當延展的函式與操作子群。
XPath2.0實際上是XQuery1.0的子集合。它提供了一個for表達式。該式是XQuery裡“FLWOR”表達式的縮減版。利用列出XQuery省去的部分來描述該語言是可能的。主要範例是查詢前導語(query prolog)、元素和屬性建構式、“FLWOR”語法的餘項式、以及typeswitch表達式。



















