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/XPATH] récupération de valeur avec des espaces


Sujet :

XSL/XSLT/XPATH XML

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Octobre 2006
    Messages : 28
    Points : 19
    Points
    19
    Par défaut [XSLT/XPATH] récupération de valeur avec des espaces
    Bonjour

    Voila je réalise une application qui transforme du XML en HTML à l'aide de XSLT. Dans ce code HTML je dois écrire des en-tête de fonctions, ces fonctions auront en entrée des données de la feuille XML.

    Le problème c'est que quand je récupère les données de la feuille XML via une requête XPATH, il y a un ajout d'espace avant et après la donnée. Et c'est un problème car dans l'en-tête de la fonction Javascript c'est des chaines de caractères qui sont envoyé donc elle ont aussi les espaces

    Extrait du code XSLT:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    	<xsl:template match="donnee">
    		<xsl:param name="positionEnr" />
     
    		<xsl:text>'</xsl:text><xsl:value-of 
    		      select="/rep/donnee[@idColonne = ./@idColonne]"/>
                       <xsl:text>'</xsl:text>
     
    		<xsl:if test="position() &lt; count(../donnee)">
    		<xsl:text>,</xsl:text>
    		</xsl:if>
    	</xsl:template>
    Par contre les données XML sont encapsulées dans un CDATA (je saie pas si sa joue) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
             <donnee idColonne="0">
                <![CDATA[1439]]>
             </donnee>
             <donnee idColonne="0">
                <![CDATA[1439]]>
             </donnee>
    Résultat de la transformation :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    '
                1439
             ','
                1439
             '

    Voila il doit juste y avoir un truc a changer quelque part dans la déclaration de la feuille XSLT ou autre mais je cherche et je trouve rien de concluant.

  2. #2
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    Si tous ces caractères étaient contenus dans un noeud tu pourrais utiliser l'élement xsl:strip-space, mais dans ton cas je vois pas de solution, à part tout mettre sur une ligne dans le xsl.

  3. #3
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    Il y a peut être un moyen tordu avec la fonction "normalize-space".
    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
    16
    17
    18
    19
    20
    <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
      <xsl:variable name="test"><xsl:apply-templates select="//donnee"><xsl:with-param name="positionEnr">1</xsl:with-param></xsl:apply-templates></xsl:variable>
     
      <xsl:template match="/">
        <xsl:value-of select="normalize-space($test)"/>
      </xsl:template>
     
      <xsl:template match="donnee">
    		<xsl:param name="positionEnr" />
     
    		<xsl:text>'</xsl:text><xsl:value-of 
    		      select="/rep/donnee[@idColonne = ./@idColonne]"/>
                       <xsl:text>'</xsl:text>
     
    		<xsl:if test="position() &lt; count(../donnee)">
    		<xsl:text>,</xsl:text>
    		</xsl:if>
    	</xsl:template>
    </xsl:stylesheet>

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Octobre 2006
    Messages : 28
    Points : 19
    Points
    19
    Par défaut
    Merci de tes réponses je vais essayer ça tout de suite.

  5. #5
    Membre éprouvé
    Profil pro
    Responsable Dev
    Inscrit en
    Décembre 2003
    Messages
    788
    Détails du profil
    Informations personnelles :
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Responsable Dev

    Informations forums :
    Inscription : Décembre 2003
    Messages : 788
    Points : 1 063
    Points
    1 063
    Par défaut
    sinon tu peux utiliser en même temps la fonction translate : pour remplacer ta chaine vide par rien et normalize-space

    cela pourrais donner un truc comme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    translate(normalize-space(.),'&#x20;&#xa;&#xd;&#x9;',' ')

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Octobre 2006
    Messages : 28
    Points : 19
    Points
    19
    Par défaut
    Je te remercie beaucoup car sa marche, les espaces avant et après sont bien supprimer.
    Merci encore

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

Discussions similaires

  1. Réponses: 11
    Dernier message: 01/04/2008, 18h13
  2. [VB.NET] Compléter une chaine avec des espaces
    Par Lois dans le forum Windows Forms
    Réponses: 4
    Dernier message: 24/03/2005, 09h09
  3. Réponses: 8
    Dernier message: 09/03/2005, 10h47
  4. Réponses: 2
    Dernier message: 08/07/2004, 01h04
  5. Réponses: 2
    Dernier message: 06/12/2002, 07h50

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