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: Sorting in XSLT

[xml-tech] Re: Sorting in XSLT

Auteur: Eric van der Vlist <vdv@dyomedea.com>
Date: 13/03/2008 - 13:59
X-Mailer: Evolution 2.12.1

Bonjour,
Le jeudi 13 mars 2008 à 14:06 +0100, hufflen jean-michel a écrit :
> Bonjour à tous,
>
> Il s'agit plus d'une demande de confirmation qu'une véritable question...
> mais sait-on jamais... au cas où...

:)

> Considérons la spécification suivante, donnée sous forme d'un extrait de
> DTD :
>
> <!ELEMENT bibliography (item*)>
> <!ELEMENT item (authors,...)>
> <!ELEMENT authors (person*)>
> <!ELEMENT person (lastname,firstname)>
> <!ELEMENT lastname (#PCDATA)>
> <!ELEMENT firstname (#PCDATA)>
>
> Comment écrire en XSLT, un tri d'une bibliographie par ordre croissant sur
> les noms des auteurs ?

Il y a plusieurs manières de comprendre votre question exposée comme
elle est :) ...

Si vous avez trois auteurs A, B et C, comment comparez-vous B, A et A,
C?

Si vous considérez la liste d'auteurs pour une même entrée comme une
liste ordonnée, (A, C) sera avant (B, A). Par contre, si vous le
considérez les listes d'auteurs comme des ensembles non ordonnés, vous
pouvez considérer que B, A doit être écrit de manière réordonnée comme
A, B et doit être avant A, C!

> S'il n'y en avait que deux au maximum, on pourrait
> écrire quelque chose comme :
>
> <xsl:apply-templates select="item">
> <xsl:sort select="authors/person[1]/lastname"/>
> <xsl:sort select="authors/person[1]/firstname"/>
> <xsl:sort select="authors/person[2]/lastname"/>
> <xsl:sort select="authors/person[2]/firstname"/>
> </xsl:apply-templates>

Cela semble indiquer que ma première option est celle que vous
retenez...

> ... mais en l'absence d'informations sur le plus grand nombre possible
> d'auteurs, cette méthode est inapplicable.

Oui, sauf si ce manière un peu bestiale, vous considérez qu'il n'y aura
jamais plus de... disons 50 ou 100 auteurs et que la probabilité que ce
nombre soit dépassé est tellement faible que cela ne serait pas
dramatique que l'ordre de tri soit aléatoire dans ce cas.

Ce n'est pas très élégant, mais c'est sans doute la solution la plus
facile à mettre en oeuvre.

> En cherchant sur le "Net", j'ai vu des endroits où l'on propose un
> contournement : récupérer la concaténation de tous les noms et prénoms des
> auteurs et se baser sur cette gigantesque chaîne. Mais voici quel est
> l'inconvénient que j'y vois ; considérons les deux noms suivants :
>
> <person> <!-- Nom [1]. -->
> <lastname>Hood</lastname>
> <firstname>Robin Locksleyy</firstname>
> </person>
>
> <person> <!-- Nom [2]. -->
> <lastname>Hood Robin</lastname>
> <firstname>Locksley</firstname>
> </person>
>
> Si l'on se base sur des concaténations avec insertion d'espaces, les deux
> chaînes résultantes sont :
> "Hood Robin Locksleyy" et "Hood Robin Locksley"
> moyennant quoi [2] < [1]. Mais si l'on se base d'abord sur les noms de
> famille, et si besoin est sur les prénoms, alors [1] < [2].

Oui, il faudrait utiliser comme séparateur un caractère venant après les
caractères utilisés pour les noms et prénoms...

> Qu'en pensez-vous ? Y a-t-il finalement un moyen élégant d'exprimer un tel
> tri sans passer par une interface avec un langage de programmation ?

Cela dépend de ce que vous appelez élégant :) ...

Je pense qu'il doit y avoir moyen d'écrire cela en groupant de manière
récursive par lastname[i] puis firstname[i], lastname[i+1], firstname[i
+1] mais cela risque d'être assez fastidieux, surtout en XSLT 1.0... Si
vous aimez les casse-têtes, vous pouvez tenter l'expérience et nous
tenir au courant!

Cordialement,

Eric van der Vlist

> Bien à vous,
>
> J.-M. H.

-- 
GPG-PGP: 2A528005
Le premier annuaire des apiculteurs 100% XML!
                                                http://apiculteurs.info/
------------------------------------------------------------------------
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
------------------------------------------------------------------------
-- Attached file included as plaintext by Ecartis --
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.6 (GNU/Linux)
iD8DBQBH2TMuDvn+ZCpSgAURAniyAJsEVCwffDgsM+bZbp90ArU9gxWpXQCglSbq
7HVDNfVUeTrMnfxeKLWXjjw=
=8xuW
-----END PGP SIGNATURE-----
--
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 Thu Mar 13 14:58:43 2008

Archive générée par hypermail 2.1.8 le 27/03/2008 - 19:53 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