必威电竞|足球世界杯竞猜平台

XPath
來源:互聯網

XPath即為XML路徑語言,它是一種用來確定XML(標準通用標記語言的子集)文檔中某部分位置的語言。

簡介

XPath即為XML路徑語言(XML Path Language),它是一種用來確定XML文檔中某部分位置的語言。

XPath基于XML的樹狀結構,提供在數據結構樹中找尋節點的能力。起初XPath的提出的初衷是將其作為一個通用的、介于XPointer與XSL間的語法模型。但是XPath很快的被開發者采用來當作小型查詢語言。

語法

選取節點XPath使用路徑表達式在XML文檔中選取節點。節點是通過沿著路徑或者step來選取的。

下面在下面的表格中,我們已列出了一些路徑表達式以及表達式的結果:列出了最有用的路徑表達式:

在下面的表格中,我們已列出了一些路徑表達式以及表達式的結果.

表達式

XPath使用路徑表達式來選取XML文檔中的節點或者節點集。這些路徑表達式和我們在常規的電腦文件系統中看到的表達式非常相似。路徑表達式是從一個XML節點(當前的上下文節點)到另一個節點、或一組節點的書面步驟順序。這些步驟以“/”字符分開,每一步有三個構成成分:

1、軸描述(用最直接的方式接近目標節點)

2、節點測試(用于篩選節點位置和名稱)

3、節點描述(用于篩選節點的屬性和子節點特征)

一般情況下,我們使用簡寫后的語法。雖然完整的軸描述是一種更加貼近人類語言,利用自然語言的單詞和語法來書寫的描述方式,但是相比之下也更加羅嗦。

運算符

下面列出了可用在?XPath?表達式中的運算符:

標準函數

XPath含有超過100個內建的函數。這些函數用于字符串值、數值,日期和時間比較、節點和QName處理、序列處理、邏輯值等等。

使用

XPath是XSLT標準中的主要元素。如果沒有XPath方面的知識,您就無法創建XSLT文檔。

XQuery和XPointer均構建于XPath表達式之上。XQuery1.0和XPath2.0共享相同的數據模型,并支持相同的函數和運算符。

標準

XPath于1999年11月16日成為W3C標準。

XPath被設計供XSLT、XPointer以及其他XML解析軟件使用。

軸定義

軸可定義相對于當前節點的節點集。

步(step)包括:

軸(axis)

定義所選節點與當前節點之間的樹關系

節點測試(node-test)

識別某個軸內部的節點

零個或者更多謂語(predicate)

更深入地提煉所選的節點集

步的語法:

軸名稱::節點測試[謂語]

實例

節點

節點(Node)是XPath的術語。在XPath中,有七種類型的節點:元素、屬性、文本、命名空間、處理指令、注釋以及文檔(根)節點。XML文檔是被作為節點樹來對待的。樹的根被稱為文檔節點或者根節點。

父(Parent)

每個元素以及屬性都有一個父。

在下面的例子中,book元素是?title、author、year?以及price元素的父:

HarryPotter

JK.Rowling

2005

29.99

子(Children)

元素節點可有零個、一個或多個子。

在下面的例子中,title、author、year以及price元素都是book元素的子:

HarryPotter

JK.Rowling

2005

29.99

同胞(Sibling)

擁有相同的父的節點

在下面的例子中,title、author、year?以及?price?元素都是同胞:

HarryPotter

JK.Rowling

2005

29.99

先輩(Ancestor)

某節點的父、父的父,等等。

在下面的例子中,title?元素的先輩是?book?元素和?bookstore?元素:

HarryPotter

JK.Rowling

2005

29.99

后代(Descendant)

某個節點的子,子的子,等等。

在下面的例子中,bookstore?的后代是?book、title、author、year?以及?price?元素:

HarryPotter

JK.Rowling

2005

29.99

存取函數

名稱說明

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日發表。XPath?2.0目前正在W3C審核過程的最終階段。XPath?2.0表達了XPath語言在大小與能力上顯著的增加。

最值得一提的改變是XPath2.0有了更豐富的型別系統;XPath2.0支持不可分割型態,如在XML?Schema內建型態定義一樣,并且也可自綱要(schema)導入用戶自定型別?,F在每個值都是一個序列(一個單一不可分割值或節點都被視為長度一的序列)。XPath1.0節點組被節點序列取代,它可以是任何順序。

為了支持更豐富的型別組,XPath2.0提供相當延展的函式與操作子群。

XPath2.0實際上是XQuery1.0的子集合。它提供了一個for表達式。該式是XQuery里“FLWOR”表達式的縮減版。利用列出XQuery省去的部分來描述該語言是可能的。主要范例是查詢前導語(query?Prolog)、元素和屬性建構式、“FLWOR”語法的余項式、以及typeswitch表達式。

實例

參考資料 >

生活家百科家居網