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 :

[XSL] Probléme de compraraison de données


Sujet :

XSL/XSLT/XPATH XML

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de dragonfly
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    464
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 464
    Par défaut [XSL] Probléme de compraraison de données
    Bonjour à tous,

    j'ai un soucis que je comprend pas trop, je fais un test :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    	     <xsl:when test="document('mantis594.xml')/Workbook/Worksheet/Table/Row[contains(normalize-space(@fileRef),normalize-space(Cell/Data))]/Cell/Data">
    Mais le probléme c'est dans le contains la variable @fileRef (par ex contient "Varplop" ne semble pas fonctionner.
    Je m'explique, lorsque je remplace cette variable par la valeur du fichier ("Varplop"), le test est à true, mais quand je met la variable il est à false (j'affiche cette valeur plus bas donc je suis sur que c'est la bonne valeur ("Varplop")).

    voici le code entier pour plus de clarté.

    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
     
    	<xsl:template match="/">
    		<xsl:comment> $RCSfile: top_i_affichage_business_view.xsl,v $ </xsl:comment>
    		<html>
    			<xsl:call-template name="GnxHead"/>
    			<body style="liste">
    			  <!-- LISTE DES BUSINESS VIEWS PAR ESNEMBLE GLOBAL -->
            <h1>
    					<xsl:value-of select="$LBL.ELTS03"/>
    				</h1>
              	<table border="0" cellpadding="0" cellspacing="0" class="liste" width="90%" align="center">
    							<xsl:apply-templates select="document('configuration.xml')/egx:config/egx:application/egx:presentation/egx:xsl" mode="VS">
    								<xsl:sort select="@name"/>
    							</xsl:apply-templates>
    						</table>
    </body>
    		</html>
    	</xsl:template>
     
    	<!-- LISTE DES BUSINESS VIEWS UTILISANT LA VIEWSTRUCT (lien vers détail de la structure) -->
    	<xsl:template match="egx:xsl" mode="VS">
    	   <tr>
         <xsl:choose>
    	     <xsl:when test="document('mantis594.xml')/Workbook/Worksheet/Table/Row[contains(normalize-space(@fileRef),normalize-space(Cell/Data))]/Cell/Data">
    	       <xsl:attribute name="style">background-color:red;</xsl:attribute>
    	     </xsl:when>
    	     <xsl:otherwise>
      	     <xsl:attribute name="class">l{position() mod 2}</xsl:attribute>
           </xsl:otherwise>
         </xsl:choose>
     
    			<td>
    			<xsl:value-of select="../../egx:businessview_def/egx:businessview[@name=current()/@businessview]/@name"/>
    			</td>
    			<td>
    			   <xsl:value-of select="@fileRef"/>
    			</td>
    			<td>
    			   <xsl:value-of select="@lang"/>
    			</td>
    			<td>
    			   <xsl:value-of select="@support"/>
    			</td>
    		</tr>
    	</xsl:template>
    </xsl:stylesheet>

    Merci d'avance
    Bye

  2. #2
    Membre Expert 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
    Par défaut
    De ce que je comprends @fileRef est un attribut de egxsl et non pas de Row : il faut donc le mettre dans une variable et accéder à cette variable

  3. #3
    Membre éclairé Avatar de dragonfly
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    464
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 464
    Par défaut
    MERCI MERCI

    Tu m'as ouvert les yeux sur l'erreur qui il y'avait, je n'ai pas utilisé de variable (en XSL les variables sont pas super bien gérable), mais j'ai rajouté un piti "current()/" juste devant.
    Ce qui donne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    	     <xsl:when test="document('mantis594.xml')/Workbook/Worksheet/Table/Row[contains(normalize-space(current()/@fileRef),normalize-space(Cell/Data))]/Cell/Data">
    Encore merci

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

Discussions similaires

  1. [XSL~FO][nFop][C#] Problème d'affichage de données
    Par SoaB dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 04/01/2007, 12h04
  2. Réponses: 5
    Dernier message: 11/03/2004, 15h34
  3. [Designer] Problème de transfert de données entre modul
    Par BILLYPATOU dans le forum Designer
    Réponses: 11
    Dernier message: 09/03/2004, 18h15
  4. Problème de rafraîchissement de données...
    Par Alain Dionne dans le forum Bases de données
    Réponses: 3
    Dernier message: 06/03/2004, 21h07
  5. [Interbase 7] Problème d'insertion de données
    Par Tuscelan dans le forum InterBase
    Réponses: 12
    Dernier message: 19/11/2003, 22h58

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