Cliquez ici.
Accueil
 chercher             Plan du site             Info (English version) 
L'histoire de XML s'écrit en ce moment même. XMLfr vous aide à la suivre et à en dégager les tendances.Les listes de discussions XMLfr sont à votre disposition pour réagir sur nos articles ou simplement poser une question.Si vous ètes passionnée(e) par XML, pourquoi ne pas en faire votre métier ?XMLfr n'est heureusement pas le seul site où l'on parle de XML. Découvrez les autres grâce à XMLfr et à l'ODP.Les partenaires grâce auxquels XMLfr peut se développer.Pour tout savoir sur XMLfr.XMLfr sans fil, c'est possible !Pour ceux qui veulent vraiment en savoir plus sur XML.L'index du site.
 Commentaires et questions non techniques.Commentaires et questions techniques.

 
Cliquez ici.

xml tech : Technologies XML

[xml-tech] Re: Tester le numéro d'ordre d'un parent ou d'un ancestor

[xml-tech] Re: Tester le numéro d'ordre d'un parent ou d'un ancestor

Auteur: Eric van der Vlist <vdv@dyomedea.com>
Date: 21/12/2004 - 10:36
X-Mailer: Evolution 2.0.2

Bonjour,

Le mardi 21 décembre 2004 à 11:12 +0100, Myriam GOUTTE a écrit :
> Bonjour,
>
> Je ne trouve pas la syntaxe pour tester sur un noeud le N° d'ordre de
> plusieurs ancêtres.
> Voilà mon cas de figure :
> <AAA>
> <BBB>
> <CCC>
> <DDD>
> <H1>
> .....
>
> Je suis sur le noeud H1 (<xsl:template match="H1">)
> J'ai besoin de tester le N° d'ordre des noeuds <DDD> et <AAA>
> c'est-à-dire :
> /AAA[position() = 1]/BBB/CCC/DDD[position() = 1]/H1
>
> J'ai essayé plusieurs solutions dont :
> <xsl:when test="ancestor::AAA[position() = 1]">
> <xsl:when test="ancestor::AAA[position() = 1] AND parent::node()[position()
> = 1]">
> Il passe sur le test (true) même si c'est faux !

Le problème de la fonction "position()" dans ce contexte c'est qu'il
s'agit de la position dans la liste de noeuds sélectionnés (dans le
contexte de cette expression XPath se sera toujours 1) alors que vous
voulez la position dans le document.

Pour cela, il faut compter le nombre de noeuds précédents en utilisant
soit preceding-sibling (si vous ne vous intéressez qu'au noeuds ayant le
même parent soit preceding si vous vous intéressez à tous les noeuds.
Cela pourra donner :

<xsl:when test="ancestor::AAA[count(preceding-sibling::AAA) = 0] and
ancestor::DDD[count(preceding-sibling::DDD) = 0]">

C'est un peu plus simple dans la clause match d'un template où vous pourriez écrire :

<xsl:template match="AAA[count(preceding-sibling::AAA) =
0]/BBB/CCC/DDD[count(preceding-sibling::DDD) = 0]/H1">

Enfin, si vous testez toujours que c'est le premier, vous n'avez pas
besoin de compter le nombre de précédents et pouvez simplifier
DDD[count(preceding-sibling::DDD) = 0] en
DDD[not(preceding-sibling::DDD)] (id pour AAA).

Cordialement,

Eric van der Vlist

-- 
Read me on XML.com.
                                            http://www.xml.com/pub/au/74
------------------------------------------------------------------------
Eric van der Vlist       http://xmlfr.org            http://dyomedea.com
(ISO) RELAX NG   ISBN:0-596-00421-4 http://oreilly.com/catalog/relax
(W3C) XML Schema ISBN:0-596-00252-1 http://oreilly.com/catalog/xmlschema
------------------------------------------------------------------------
--
Devenez redacteur <XML>fr et contribuez au developpement du
xml francophone (http://xmlfr.org/infos/redacteurs/) !
Liste de diffusion "xml-tech@xmlfr.org" (http://xmlfr.org).
Cette liste est a votre disposition pour discuter en francais de 
tout sujet technique lie a XML.
Pour resilier votre abonnement, envoyez un message contenant 
la commande "unsubscribe" a xml-tech-request@xmlfr.org
(mailto:xml-tech-request@xmlfr.org?Subject=unsubscribe)
Received on Tue Dec 21 11:36:23 2004

Archive générée par hypermail 2.1.8 le 31/12/2004 - 11:12 UTC

webmaster@xmlfr.org

 

xml tech

Discussions techniques au sujet de XML.

Cette liste est à votre disposition pour discuter en français de tout sujet technique lié à XML.



Devenez rédacteur <XML>fr et contribuez au développement du xml francophone !
Les documents publiés sur ce site le sont sous licence "Open Content"
Conception graphique
  l.henriot@online.fr  

Conception, réalisation et hébergement