XPath軸
XMLサンプルドキュメント
以下の例では、次のXMLドキュメントを使用します。
<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
<book>
<title lang="en">Harry Potter</title>
<price>29.99</price>
</book>
<book>
<title lang="en">Learning XML</title>
<price>39.95</price>
</book>
</bookstore>
XPath軸
軸は、コンテキスト(現在の)ノードとの関係を表し、ツリー上のそのノードに関連するノードを見つけるために使用されます。
AxisName | Result |
---|---|
ancestor | Selects all ancestors (parent, grandparent, etc.) of the current node |
ancestor-or-self | Selects all ancestors (parent, grandparent, etc.) of the current node and the current node itself |
attribute | Selects all attributes of the current node |
child | Selects all children of the current node |
descendant | Selects all descendants (children, grandchildren, etc.) of the current node |
descendant-or-self | Selects all descendants (children, grandchildren, etc.) of the current node and the current node itself |
following | Selects everything in the document after the closing tag of the current node |
following-sibling | Selects all siblings after the current node |
namespace | Selects all namespace nodes of the current node |
parent | Selects the parent of the current node |
preceding | Selects all nodes that appear before the current node in the document, except ancestors, attribute nodes and namespace nodes |
preceding-sibling | Selects all siblings before the current node |
self | Selects the current node |
ロケーションパス式
ロケーションパスは、絶対パスでも相対パスでもかまいません。
絶対ロケーションパスはスラッシュ(/)で始まり、相対ロケーションパスはスラッシュ(/)で始まりません。どちらの場合も、ロケーションパスは1つ以上のステップで構成され、各ステップはスラッシュで区切られます。
An absolute location path:
/step/step/...
A relative location path:
step/step/...
各ステップは、現在のノードセット内のノードに対して評価されます。
ステップは次のもので構成されます。
- 軸(選択したノードと現在のノード間のツリー関係を定義します)
- ノードテスト(軸内のノードを識別します)
- 0個以上の述語(選択したノードセットをさらに絞り込むため)
ロケーションステップの構文は次のとおりです。
axisname::nodetest[predicate]
例
Example | Result |
---|---|
child::book | Selects all book nodes that are children of the current node |
attribute::lang | Selects the lang attribute of the current node |
child::* | Selects all element children of the current node |
attribute::* | Selects all attributes of the current node |
child::text() | Selects all text node children of the current node |
child::node() | Selects all children of the current node |
descendant::book | Selects all book descendants of the current node |
ancestor::book | Selects all book ancestors of the current node |
ancestor-or-self::book | Selects all book ancestors of the current node - and the current as well if it is a book node |
child::*/child::price | Selects all price grandchildren of the current node |