Xpath XPath is a language for finding information in an XML document.
training
Naviguer dans les documents XML avec XPath Introduction Les axes Les filtres Les prédicats Les fonctions prédéfinies Syntaxe abrégée
Naviguer dans les documents XML avec XPath Introduction Les axes Les filtres Les prédicats Les fonctions prédéfinies Syntaxe abrégée
Introduction Chaque document XML est une instance d'un arbre XML. XPath est un langage général d'adressage dans cet arbre XML.
Remarques Le nœud racine est unique et obligatoire Il ne faut pas le confondre avec l'élément document, souvent appelé racine du document. Cette distinction est justifiée par le fait que quatre types de nœuds différents peuvent être fils du nœud racine. le nœud déclaration de domaine les instructions de traitement les commentaires l'élément document qui est unique Si les nœuds sont ordonnés, les attributs ne le sont pas, ainsi nous ne pourrons pas recherche le nième attributs.
LocationPath [1] LocationPath ::= RelativeLocationPath | AbsoluteLocationPath [2] AbsoluteLocationPath ::= '/' RelativeLocationPath? | AbbreviatedAbsoluteLocationPath [3] RelativeLocationPath ::= Step | RelativeLocationPath '/' Step | AbbreviatedRelativeLocationPath Un RelativeLocationPath sert à sélectionner un ensemble de noeuds basés sur leur position par rapport au noeud contextuel. Un AbsoluteLocationPath sert à sélectionner un ensemble de noeuds basées sur leur position dans le document par rapport au noeud racine.
Récursivité [1] LocationPath ::= RelativeLocationPath | AbsoluteLocationPath [2] AbsoluteLocationPath ::= '/' RelativeLocationPath? | AbbreviatedAbsoluteLocationPath [3] RelativeLocationPath ::= Step | RelativeLocationPath '/' Step | AbbreviatedRelativeLocationPath Un RelativeLocationPath sert à sélectionner un ensemble de noeuds basés sur leur position par rapport au noeud contextuel. Un AbsoluteLocationPath sert à sélectionner un ensemble de noeuds basées sur leur position dans le document par rapport au noeud racine.
Exemple /child::doc /child::chapter[position()=5]/ child:: section[ position()= 2] selects the second section of the fifth chapter of the doc document element
Exemple child::para [position()=2][attribute::pe="warning"] selects the second para child of the context node if that child has a type attribute with value warning
Naviguer dans les documents XML avec XPath Le langage dadressage utilise des chemins pour désigner un ensemble dobjets Une étape de localisation se fait en 3 temps : un axe, est un chemin à travers l'arbre du document, débutant au nœud origine et suivant une relation particulière entre les nœuds. un filtre, qui spécifie le type du noeud obtenus par l'étape de localisation 0 ou n prédicats, qui sont des expressions arbitraires pour raffiner l'ensemble des noeuds
Exemples child::para[ position()=5][attribute::type="warning"] selects the fifth para child of the context node if that child has a type attribute with value warning Une étape de localisation se fait en 3 temps : un axe, est un chemin à travers l'arbre du document, débutant au nœud origine et suivant une relation particulière entre les nœuds. un filtre, qui spécifie le type du noeud obtenus par l'étape de localisation 0 ou n prédicats, qui sont des expressions arbitraires pour raffiner l'ensemble des noeuds
Naviguer dans les documents XML avec XPath Introduction Les axes Les filtres Les prédicats Les fonctions prédéfinies Syntaxe abrégée
AxisName Un AxisName est utilisé dans un Step pour identifier un chemin à suivre depuis un nœud donné vers les autres nœuds liés. AxisName ::= | 'ancestor' | 'ancestor-or-self' | 'attribute' | 'child' | 'descendant' | 'descendant-or-self' | 'following' | 'following-sibling' | 'namespace' | 'parent' | 'preceding' | 'preceding-sibling' | 'self'
| 'ancestor'
1 2
'ancestor-or-self'
'ancestor-or-self' 2 3 1
| 'child'
1 2
| 'descendant'
| 'descendant-or-self'
| 'following'
1 32 4
| 'following-sibling'
1 2
| 'parent'
1
| 'preceding'
3 12
| 'preceding-sibling'
1
| 'self' 1
AxisSpecifier Un AxisSpecifier est soit un nom d'axe, soit une abréviation pour un nom d'axe. Il définit une direction de navigation à travers le document en définissant une liste ordonnée de nœuds qui peuvent être visités. AxisSpecifier ::= AxisName '::' | AbbreviatedAxisSpecifier [13] AbbreviatedAxisSpecifier ::=
Exemple ancestor:: spécifie l'axe ancêtre Preceding-sibling:: Spécifie l'axe enfant spécifie l'axe attribut
Naviguer dans les documents XML avec XPath Introduction Les axes Les filtres Les prédicats Les fonctions prédéfinies Syntaxe abrégée
Predicate Un prédicat est une expression qualificative utilisée pour sélectionner un sous ensemble des noeuds d'une ensemble de noeuds ou de Step. [8] Predicate ::= '[' PredicateExpr ']' # noter les []PredicateExpr [9] PredicateExpr ::= ExprExpr
Exemple Para[ 1] ou Para[ position()=1] Le premier élément enfant du noeud contextuel para[ last()] le dernier élément enfant du noeud contextuel.
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute //CCC/self::*
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute //CCC/child::*
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute //CCC/parent::*
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute //DDD/descendant::*
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute //DDD/ancestor::*
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute //GGG/preceding::*
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute //GGG/preceding-sibling::*
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute //*[attribute::id]
Naviguer dans les documents XML avec XPath Introduction Les axes Les filtres Les prédicats Les fonctions prédéfinies Syntaxe abrégée
FilterExpr FilterExpr est utilisé pour appliquer un ou plusieurs Predicates à un ensemble de noeuds, en sélectionnant un sous ensemble de ces noeuds satisfaisant certaines conditions. [20] FilterExpr ::= PrimaryExpr| FilterExpr PredicatePrimaryExprFilterExprPredicate
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute Les filtres: /, *, element Les prédicats: [expression], les opérations: +, -, *, div, mod, >, >=, <, <=, =, != Syntaxe abrégée: /AAA/*/DDD/*
Naviguer dans les documents XML avec XPath Introduction Les axes Les filtres Les prédicats Les fonctions prédéfinies Syntaxe abrégée
Naviguer dans les documents XML avec XPath (3) Les axes: self, child, parent, descendant, descendant-or-self, ancestor, ancestor-or-self, preceding, preceding-sibling, following, following-sibling, attribute Les filtres: /, *, element Les prédicats: [expression], les opérations: +, -, *, div, mod, >, >=, <, <=, =, != Syntaxe abrégée: //BBB[attribute::id=bbb]
Syntaxe abrégée./totoself::toto totochild::toto (et non //toto/descendant-or-self::node()/child::toto.//totodescendant-or-self::node()/child::toto toto[2]child::toto[position() = 2]