IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

XSL/XSLT/XPATH XML Discussion :

[XSLT] trier une liste avec une variable


Sujet :

XSL/XSLT/XPATH XML

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 6
    Points : 7
    Points
    7
    Par défaut [XSLT] trier une liste avec une variable
    Bonjour !!

    J'ai un petit souci : je cherche à trier une liste en fonction de la valeur d'une variable. Par exemple, si la variable vaut 'nom', je souhaite trier par nom. Si elle vaut 'matricule', la liste est triée par matricule.

    Quand je mets :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:sort select="mElement/mAgent/mMatricule" lang="FR" data-type="{$DataTypeTri}"/>
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:sort select="mElement/mAgent/mNom" lang="FR" data-type="{$DataTypeTri}"/>
    le tri s'effectue sans problème. Mais quand je met une variable dans le select, ça foire, alors que champTri contient bien 'mElement/mAgent/mNom' :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:sort select="$champTri" lang="FR" data-type="{$DataTypeTri}"/>
    même si je mets ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:sort select="*[name(.)=$champTri]" lang="FR" data-type="{$DataTypeTri}"/>
    Les variables sont définies bien avant le tri par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <xsl:variable name="valeurTri">
       <xsl:value-of select="..."/>
    </xsl:variable>
    <xsl:variable name="champTri">
       <xsl:if test="($valeurTri = 'MATRICULE')">mElement/mAgent/mMatricule</xsl:if>
       <xsl:if test="($valeurTri = 'NOM')">mElement/mAgent/mNom</xsl:if>
    </xsl:variable>
    <xsl:variable name="DataTypeTri">
       <xsl:if test="($valeurTri = 'MATRICULE')">number</xsl:if>
       <xsl:if test="($valeurTri = 'NOM')">text</xsl:if>
    </xsl:variable>
    Ces variables ont bien pour valeur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    valeurTri = MATRICULE
    champTri = mElement/mAgent/mMatricule
    DataTypeTri = number
    Quelqu'un saurait-il m'expliquer pourquoi ça ne marche pas et ce qu'il faudrait faire pour y remédier ?

    Merci

  2. #2
    Membre éprouvé Avatar de alain.couthures
    Profil pro
    Gérant
    Inscrit en
    Avril 2007
    Messages
    902
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Gérant

    Informations forums :
    Inscription : Avril 2007
    Messages : 902
    Points : 1 247
    Points
    1 247
    Par défaut
    Dans l'expression
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select="*[name(.)=$champTri]"
    name() correspond toujours à un nom d'élément (mMatricule ou mAgent) et non pas à la concaténation des noms des ancêtres séparés par des /.

    Je ne suis pas sûr qu'il y ait une solution à votre problème en l'état en XPath 1.0... Si votre arborescence est régulière et que les noms d'éléments y sont uniques (pas d'autre élément que mAgent à avoir un descendant s'appelant mNom), je réduirais $champTri au dernier élément et je chercherais dans cette direction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select="descendant::*[name()=$champTri]"
    Formulaires XForms sur tous navigateurs sans extension à installer (architecture XRX) : http://www.agencexml.com/xsltforms/

  3. #3
    Rédacteur

    Avatar de Erwy
    Homme Profil pro
    Développeur Web
    Inscrit en
    Novembre 2003
    Messages
    4 967
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2003
    Messages : 4 967
    Points : 10 927
    Points
    10 927
    Par défaut
    Citation Envoyé par alain.couthures Voir le message

    Je ne suis pas sûr qu'il y ait une solution à votre problème en l'état en XPath 1.0...
    Je suis d'accord, par contre, si on connait à l'ensemble des tris possible on peut contourner le problème en passant par des clés.
    La valeur passé en variable est alors le nom de la clé

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 6
    Points : 7
    Points
    7
    Par défaut
    Youhou !!! Ca marche !!

    J'ai fait comme vous avez dit, alain.couthures :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    ...
    <xsl:variable name="champTri">
       <xsl:if test="($valeurTri = 'MATRICULE')">mMatricule</xsl:if>
       <xsl:if test="($valeurTri = 'NOM')">mNom</xsl:if>
    </xsl:variable>
    ...
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:sort select="descendant::*[name()=$champTri]" lang="FR" data-type="{$DataTypeTri}"/>
    Erwy : Je ne vois pas trop comment tu ferais exactement. Ca m'intéresserait.

    Merci à vous deux d'avoir répondu.
    Ieuthm

  5. #5
    Rédacteur

    Avatar de Erwy
    Homme Profil pro
    Développeur Web
    Inscrit en
    Novembre 2003
    Messages
    4 967
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2003
    Messages : 4 967
    Points : 10 927
    Points
    10 927
    Par défaut
    Ca peut e^tre utile lors de cas de xml mal foutu (au moins pour le tri)

    imaginons des elements du type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <a d="2">
    		<b>1</b>
    		<c>
    			<d>e</d>
    			<f>'</f>
    		</c>
    	</a>
    et que tu veuilles trier les elements a soit par b,d,f voir même l'attribut d.
    le chemin en dynamique devient complexe, par contre si tu cree autant de clé que de tri, clé basée sur l'id de l'element a cela peut fonctionner

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    	<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
    	<xsl:key name="cle1" match="b" use="generate-id(parent::*)"></xsl:key>
    	<xsl:key name="cle2" match="d" use="generate-id(../parent::*)"></xsl:key>
    	<xsl:key name="cle3" match="f" use="generate-id(../parent::*)"></xsl:key>
    	<xsl:key name="cle4" match="@d" use="generate-id(parent::*)"></xsl:key>
    	<xsl:param name="nomdelacle"></xsl:param>
     
    	..
    	<xsl:apply-templates select="a">
    	<xsl:sort select="key($nomdelacle,generate-id(.))"></xsl:sort>
    	</xsl:apply-templates>
    	...
    </xsl:stylesheet>

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 13/04/2015, 11h17
  2. [XL-2003] Remplir une liste avec des variables
    Par pikameuh dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 11/05/2011, 13h33
  3. [XL-2002] Macro de comparaison d'une cellule d'une feuille avec une cellule d'une autre feuille.
    Par steelydan dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/09/2010, 12h59
  4. Réponses: 4
    Dernier message: 15/10/2009, 13h33
  5. Réponses: 2
    Dernier message: 03/05/2006, 17h00

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo