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

XML/XSL et SOAP Discussion :

prob affichage mot en gras dans un texte


Sujet :

XML/XSL et SOAP

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 8
    Points : 3
    Points
    3
    Par défaut prob affichage mot en gras dans un texte
    Bonjour,
    je suis débutante en XML/XSL et j'aurais voulu réaliser la chose suivante: mettre en gras dans un texte les mots-clé saisis par l'utilisateur.
    J'ai pense à une boucle de ce type:
    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
     
    <xsl:for-each select="...">
       <xsl:choose>
           <xsl:when test=".[mot=...]">
               <tr bgcolor="#00FF00">
                   <td><xsl:value-of-select="titre"/>
                   </td>
               </tr>
           </xsl:when>
        <xsl:otherwise>
        <tr>
              <td><xsl:value-of select="titre"/></td>
              <td><xsl:value-of select="artiste"/></td>
        </tr>
        </xsl:otherwise>
      </xsl:choose>
    </xsl:for-each>
    mais le problème c'est qu'il me faut sélectionner chaque mot du texte (qui fait au max deux lignes) et ça je ne sais pas comment faire.
    Merci à tous ceux qui prendront un peu de temps pour m'aider.
    bonne fin de journée à tous

  2. #2
    Membre confirmé Avatar de Perceval
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Mars 2003
    Messages
    355
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Distribution

    Informations forums :
    Inscription : Mars 2003
    Messages : 355
    Points : 464
    Points
    464
    Par défaut
    si tu as possibilté de faire du php, tu peux te servir des expressions régulières comme ceci =>http://www.expreg.com/voir42
    Save a tree... Eat a beaver

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    malheureusement non. c'est bien domage

  4. #4
    Expert éminent
    Avatar de GrandFather
    Inscrit en
    Mai 2004
    Messages
    4 587
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Mai 2004
    Messages : 4 587
    Points : 7 103
    Points
    7 103
    Par défaut
    Bonjour,

    il faudra en passer par l'écriture d'une fonction récursive en XSLT. Poste un exemple de ta source XML pour qu'on voit ce qu'on peut faire....
    FAQ XML
    ------------
    « Le moyen le plus sûr de cacher aux autres les limites de son savoir est de ne jamais les dépasser »
    Giacomo Leopardi

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    voila mon code. Texte 1, Texte2 et Texte3 sont des mots..

    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
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    <td>
                 <font size="2">
                      <xsl:variable name="Texte1">
                            <xsl:value-of select="translate(substring(/ROOT/PARAM/TEXTE1,2,(string-length(/ROOT/PARAM/TEXTE1)-2) ),'ABCDEFGHIJKLMNOPQRSTUVWXYZ','abcdefghijklmnopqrstuvwxyz') "/>
                      </xsl:variable>
     
                      <xsl:variable name="Texte2">
                            <xsl:value-of select="translate(substring(/ROOT/PARAM/TEXTE2,2,(string-length(/ROOT/PARAM/TEXTE2)-2) ),'ABCDEFGHIJKLMNOPQRSTUVWXYZ','abcdefghijklmnopqrstuvwxyz') "/>
                      </xsl:variable>
                      <xsl:variable name="Texte3">
                            <xsl:value-of select="translate(substring(/ROOT/PARAM/TEXTE3,2,(string-length(/ROOT/PARAM/TEXTE3)-2) ),'ABCDEFGHIJKLMNOPQRSTUVWXYZ','abcdefghijklmnopqrstuvwxyz') "/>
                      </xsl:variable>
     
                      <xsl:choose>
                           <xsl:when test="contains(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle, /ROOT/PARAM/TEXTE1)">
                                <xsl:value-of select="substring-before(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle,/ROOT/PARAM/TEXTE1)"/>
                                <xsl:text> </xsl:text>
                                <b>
                                     <xsl:value-of select="/ROOT/PARAM/TEXTE1"/>
                                </b>
                                <xsl:text> </xsl:text>
                           <xsl:value-of select="substring-after(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle,/ROOT/PARAM/TEXTE1)"/>
                    </xsl:when>
                    <xsl:when test="contains(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle, $Texte1)">
                          <xsl:value-of select="substring-before(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle,$Texte1)"/>
                           <xsl:text> </xsl:text>
                           <b>
                                <xsl:value-of select="$Texte1"/>
                            </b>
                            <xsl:text> </xsl:text>
                            <xsl:value-of select="substring-after(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle,$Texte1)"/>
                     </xsl:when>
                     <xsl:when test="contains(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle, /ROOT/PARAM/TEXTE2)">
                           <xsl:value-of select="substring-before(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle,/ROOT/PARAM/TEXTE2)"/>
                           <xsl:text> </xsl:text>
                          <b>
                              <xsl:value-of select="/ROOT/PARAM/TEXTE2"/>
                          </b>
                           <xsl:text> </xsl:text>
                           <xsl:value-of select="substring-after(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle,/ROOT/PARAM/TEXTE2)"/>
                    </xsl:when>
                    <xsl:when test="contains(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle, $Texte2)">
                          <xsl:value-of select="substring-before(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle,$Texte2)"/>
                          <xsl:text> </xsl:text>
                          <b>
                              <xsl:value-of select="$Texte2"/>
                           </b>
                            <xsl:text> </xsl:text>
                       <xsl:value-of select="substring-after(/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle,$Texte2)"/>
                  </xsl:when>
    (...)même chose avec texte3(...)                                       
                                      <xsl:otherwise>
                                        <xsl:value-of select="/ROOT/DETAILS/row[@FileNr=current()/@FileNr]/@OfficialTitle"/>
                                      </xsl:otherwise>
                                    </xsl:choose>
                                  </font>
                                </td>
    Merci beaucoup de consacrer un peu de votre temps à mon problème.

  6. #6
    Expert éminent
    Avatar de GrandFather
    Inscrit en
    Mai 2004
    Messages
    4 587
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Mai 2004
    Messages : 4 587
    Points : 7 103
    Points
    7 103
    Par défaut
    En fait, c'est un extrait de ta source XML à transformer qui serait utile, pour voir comment cela se présente...
    FAQ XML
    ------------
    « Le moyen le plus sûr de cacher aux autres les limites de son savoir est de ne jamais les dépasser »
    Giacomo Leopardi

  7. #7
    Candidat au Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    voila la partie du fichier.xml où il y a du code concernant les trois variables:

    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
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    <sql:param name="Texte1"></sql:param>
    <sql:param name="Texte1Ascii"></sql:param> 	<!-- Texte 1 converti en ascii -->
     
    <sql:param name="Texte2"></sql:param>
    <sql:param name="Texte2Ascii"></sql:param> 	<!-- Texte 3 converti en ascii -->
     
    <sql:param name="Texte3"></sql:param>
    <sql:param name="Texte3Ascii"></sql:param> 	<!-- Texte 3 converti en ascii -->
     
    <!-- Sélection des champs de recherche pour les éléments de texte -->
    <!-- Correspondance code de l'url et liste de mots -->
    declare @txt nvarchar(200);    -- chaine de texte temporaire
     
    if (not (@Texte1= ''))
      begin
         exec convert_char @Texte1Ascii, @Texte1 output;
         set @txt = dbo.GetCond(@Texte1,@Champs1);
         set @cond_dossiers = @cond_dossiers + ' and ( ';
         set @cond_dossiers = @cond_dossiers + @txt;
         if (@Texte3 = '' and @Texte2 = '') set @cond_dossiers = @cond_dossiers + ' ) ';
    end
     
    if (not (@Texte2= ''))
      begin
         exec convert_char @Texte2Ascii, @Texte2 output;
         set @txt = dbo.GetCond(@Texte2,@Champs2);
         if (@Texte1 = '')   set @cond_dossiers = @cond_dossiers + ' ( ';
         if (@L1 = 0) 		
    	set @cond_dossiers = @cond_dossiers + ' AND ( ';
    	else 	set @cond_dossiers = @cond_dossiers + ' OR ( ';
    	set @cond_dossiers = @cond_dossiers + @txt;
    set @cond_dossiers = @cond_dossiers + ' ) ';  
    	if (@Texte3 = '') set @cond_dossiers = @cond_dossiers + ' ) ';
    end
     
    if (not (@Texte3 = ''))
      begin
         exec convert_char @Texte3Ascii, @Texte3 output;
         set @txt = dbo.GetCond(@Texte3,@Champs3);
         if (@Texte1 = '' and @Texte2='') set @cond_dossiers = @cond_dossiers + ' ( ';
         if (@L2 = 0) 
    	set @cond_dossiers = @cond_dossiers + ' AND ( ';
    	else  	set @cond_dossiers = @cond_dossiers + ' OR ( ';
         set @cond_dossiers = @cond_dossiers + @txt;
         set @cond_dossiers = @cond_dossiers + ' ) ) '; 
    end
     
    select '<TEXTE1>'; select @Texte1;select '</TEXTE1>';
    select '<TEXTE1ASCII>';	select @Texte1Ascii;
    select '</TEXTE1ASCII>';
    select '<CHAMPS1>';  select @CHAMPS1; 
    select '</CHAMPS1>';
    select '<TEXTE2>';  select @TEXTE2; select '</TEXTE2>';
    select '<TEXTE2ASCII>';  select @Texte2Ascii;  
    select '</TEXTE2ASCII>';
    select '<CHAMPS2>'; select @CHAMPS2; 
    select '</CHAMPS2>';
    select '<TEXTE3>'; select @TEXTE3; select '</TEXTE3>';
    select '<TEXTE3ASCII>'; select @Texte3Ascii;
    	select '</TEXTE3ASCII>';
    select '<CHAMPS3>';  select @CHAMPS3; 
    select '</CHAMPS3>';
    bonne journée et merci encore.

Discussions similaires

  1. Réponses: 8
    Dernier message: 09/04/2013, 04h50
  2. insérer un mot sans formatage dans un texte formaté
    Par happyculteur dans le forum VBScript
    Réponses: 2
    Dernier message: 19/11/2007, 17h22
  3. Réponses: 1
    Dernier message: 01/05/2007, 10h39
  4. [VBA-W] Mot en gras dans un pied-de-page
    Par Fée_Clochette dans le forum VBA Word
    Réponses: 1
    Dernier message: 07/01/2007, 17h33
  5. affichage d'une cellule dans un text box
    Par magictom42 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 06/11/2006, 11h10

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