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 :

problème de tri et optimisatiopn


Sujet :

XSL/XSLT/XPATH XML

  1. #1
    Nouveau membre du Club
    Inscrit en
    Octobre 2002
    Messages
    74
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 74
    Points : 36
    Points
    36
    Par défaut problème de tri et optimisatiopn
    Alors voilà j'affiche sous forme de TreeView mon fichier XML dont le schéma est :

    on a 1500 personnes environ
    <PERSONNE>
    <NOM/>
    <SERVICE/>
    <ENTITE/>
    ...
    </PERSONNE>


    alors je prends dans un premier temps le fichier XML non trié, et je le trie (ca ca fonctionne bien) je récupère donc un fichier xml trié dans le bon ordre :
    1) Par entité
    2) Par Service
    3) Par nom

    maintenant je veux voir un treeview de la forme
    - Entite
    - Service
    - Nom

    et bien sur pouvoir faire un tri croissant et décroissant, mais le pb c'est que l'affichage est tout le temps dans le même ordre malgré le tri précédent. voilà la feuille XSLT :

    Si au passage vous trouvez que ma feuille de style n'est pas top, je suis preneur de vos remarques.

    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
    63
    64
    65
    66
    67
    68
    69
    <?xml version='1.0' encoding="ISO-8859-1"?> 
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
    <xsl:output indent = "yes"/>
      <xsl:template match="REPERTOIRE"> 
       <!--<UL>-->
    	<table border="0" id="Tableau1" width="98%" align="right" cellpadding="0" cellspacing="0">
     
    		<!-- ON PARCOURT LES ENTITES --> 
    		<xsl:for-each select="PERSONNE[not(ENTITE=preceding-sibling::PERSONNE/ENTITE)]/ENTITE">
    			<xsl:sort/>          
    			<xsl:variable name="currentEntite">       
    		    		<xsl:value-of select="."/>
    			</xsl:variable> 
    			<tr>
    				<td>
    					<br/>
    					<a onclick="javascript:toggle(this)" >
    						<img src="include/Images/Plus.gif"/>
    						<b id="search"><xsl:value-of select="$currentEntite"/></b>
    					</a>
    					<div style="display: none">
    						<table width="100%" cellpadding="0" cellspacing="0">
     
    								<!-- ON PARCOURT LES SERVICES DE CETTE ENTITE --> 
    								<xsl:for-each select="../../PERSONNE[ENTITE=$currentEntite and not(SERVICE=preceding-sibling::PERSONNE[1]/SERVICE)]/SERVICE">
    									<xsl:sort/> 
    			       					<xsl:variable name="currentService"> 
    										<xsl:value-of select="."/>
    			       					</xsl:variable> 
    									<tr>
    										<td width="15"/> <!-- permet de décaller... -->
    										<td>
    											<br/>
    												<a onclick="javascript:toggle(this)" >
    													<img src="include/Images/Plus.gif"/>		
    													<b id="search"><font size="2" color="#A29DF9"><xsl:value-of select="$currentService"/></font></b>
    												</a>	
    											<div style="display: none">
    												<table width="100%" cellpadding="0" cellspacing="0">
     
    													<!-- ON PARCOURT LES PERSONNES DE CE SERVICE --> 
    						       						<xsl:for-each select="../../PERSONNE[SERVICE=$currentService and ENTITE=$currentEntite]">
    						       							<xsl:sort select="NOM"/> 
    														<tr id="{NOM}" onMouseOver="this.bgColor='#ADC8E9';" onMouseOut="this.bgColor='#F5F5F5';">
    															<xsl:attribute name="ondblclick">	
    																<xsl:text disable-output-escaping="yes">popup("http://parinf02/annuaire/testXml.asp?Id=</xsl:text><xsl:value-of select="ID" /><xsl:text disable-output-escaping="yes">")</xsl:text>
    															</xsl:attribute>
    															<td width="14%"><b><xsl:value-of select="NOM"/></b></td>
    													   		<td width="14%"><xsl:value-of select="PRENOM"/></td>
    													   		<td width="11%"><xsl:value-of select="TELEPHONE"/></td>
    													   		<td width="11%"><xsl:value-of select="PORTABLE"/></td>
    													   		<td width="11%"><xsl:value-of select="FAX"/></td>
    												   			<td width="24%"><xsl:value-of select="SERVICE"/></td>
    													   		<td width="15%"><xsl:value-of select="LOCALISATION"/></td>
    							     						</tr>
    						        						</xsl:for-each>
    						        					</table>
    					        					</div>				        				
    										</td>
    									</tr>
    							</xsl:for-each> 								
    						</table>
    					</div>
    				</td>
    			</tr>
    		</xsl:for-each>                     
    	</table>
    </xsl:template> 
     </xsl:stylesheet>

  2. #2
    Nouveau membre du Club
    Inscrit en
    Octobre 2002
    Messages
    74
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 74
    Points : 36
    Points
    36
    Par défaut
    personne n'a d'idées ??? au moins pour optiimiser ??

  3. #3
    Membre régulier Avatar de agueffier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2002
    Messages : 93
    Points : 114
    Points
    114
    Par défaut
    Bonjour

    Pour faire bref, je te conseille d'utiliser des templates plutôt que des xsl:for-each. D'abord c'est plus rapide, ensuite cela améliorera la lisibilité et la maintenabilité de ton xsl.
    Une fois que tu auras fait ça, tu y verras plus clair et probablement que tu pourra simplifier tes requêtes XPATH (select="../../PERSONNE[ENTITE=$currentEntite and not(SERVICE=preceding-sibling:ERSONNE[1]/SERVICE)]/SERVICE") ou encore les optimiser en utilisant xsl:key.

  4. #4
    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
    j'ai pas repris ton code html/javascript trop complique a teste mais je fais le meme cheminement,donc tu peux adapter de plus je pars d'un fichier non trie a l'origine(pas besoin de faire un fichier trier au depart)

    mon xml test(ps ce serait sympa d'en fournir un la prochaine fois,perte de temps pour moi )
    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
    <?xml version="1.0" encoding="UTF-8"?>
    <?xml-stylesheet type="text/xsl" href="C:\Documents and Settings\AMOUREUX\Mes documents\test_xml\entite.xslt"?>
    <racine>
    	<PERSONNE>
    		<NOM>1</NOM>
    		<SERVICE>A.1</SERVICE>
    		<ENTITE>A</ENTITE>
    		<TEL>ww</TEL>
    	</PERSONNE>
    	<PERSONNE>
    		<NOM>2</NOM>
    		<SERVICE>A.2</SERVICE>
    		<ENTITE>B</ENTITE>
    		<TEL>xx</TEL>
    	</PERSONNE>
    	<PERSONNE>
    		<NOM>3</NOM>
    		<SERVICE>A.1</SERVICE>
    		<ENTITE>A</ENTITE>
    		<TEL>zz</TEL>
    	</PERSONNE>
    	<PERSONNE>
    		<NOM>4</NOM>
    		<SERVICE>B.1</SERVICE>
    		<ENTITE>B</ENTITE>
    		<TEL>uu</TEL>
    	</PERSONNE>
    	<PERSONNE>
    		<NOM>5</NOM>
    		<SERVICE>C.1</SERVICE>
    		<ENTITE>C</ENTITE>
    		<TEL>cc</TEL>
    	</PERSONNE>
    	<PERSONNE>
    		<NOM>6</NOM>
    		<SERVICE>A.2</SERVICE>
    		<ENTITE>A</ENTITE>
    		<TEL>dd</TEL>
    	</PERSONNE>
    </racine>
    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
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    <?xml version="1.0" encoding="ISO-8859-1"?>
     
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    	<xsl:output method="html" encoding="Windows-1252"/>
    	<xsl:template match="/">
    		<html>
    			<body>
    				<table>
    					<xsl:call-template name="doublon">
    						<xsl:with-param name="liste" select="racine/PERSONNE/ENTITE"/>
    					</xsl:call-template>
    				</table>
    			</body>
    		</html>
    	</xsl:template>
    	<xsl:template name="doublon">
    		<xsl:param name="liste"/>
    		<xsl:param name="result"/>
    		<xsl:variable name="valeur" select="$liste[1]"/>
    		<xsl:choose>
    			<xsl:when test="$liste[1]">
    				<xsl:choose>
    					<xsl:when test="not ($result)">
    						<xsl:call-template name="doublon">
    							<xsl:with-param name="liste" select="$liste[text()!=$valeur]"/>
    							<xsl:with-param name="result" select="$liste[1]"/>
    						</xsl:call-template>
    					</xsl:when>
    					<xsl:otherwise>
    						<xsl:call-template name="doublon">
    							<xsl:with-param name="liste" select="$liste[text()!=$valeur]"/>
    							<xsl:with-param name="result" select="$liste[1]|$result"/>
    						</xsl:call-template>
    					</xsl:otherwise>
    				</xsl:choose>
    			</xsl:when>
    			<xsl:otherwise>
    				<xsl:apply-templates select="$result">
    					<xsl:sort select="."/>
    				</xsl:apply-templates>
    			</xsl:otherwise>
    		</xsl:choose>
    	</xsl:template>
    	<xsl:template match="ENTITE">
    		<tr>
    			<td>
    				<xsl:value-of select="."/>
    			</td>
    		</tr>
    		<xsl:call-template name="doublon">
    			<xsl:with-param name="liste" select="../../PERSONNE[ENTITE=current()]/SERVICE"/>
    		</xsl:call-template>
    	</xsl:template>
     
    	<xsl:template match="SERVICE">
    	<xsl:param name="truc" select="../ENTITE"/>
    		<tr>
    			<td>
    	</td>
    			<td>
    				<xsl:value-of select="."/>
    			</td>
     
    		</tr>
    		<xsl:call-template name="doublon">
    			<xsl:with-param name="liste" select="../../PERSONNE[ENTITE=$truc and SERVICE=current()]/NOM"/>
    		</xsl:call-template>
    	</xsl:template>
    	<xsl:template match="NOM">
    		<tr>
    			<td>
    	</td>
    			<td>
    	</td>
    			<td>
    				<xsl:value-of select="."/>
    			</td>
    			<td>
    				<xsl:value-of select="../TEL"/>
    			</td>
    		</tr>
    	</xsl:template>
    </xsl:stylesheet>

  5. #5
    Membre régulier Avatar de agueffier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2002
    Messages : 93
    Points : 114
    Points
    114
    Par défaut
    Bonjour,

    si ton fichier de données est déjà trié
    alors je prends dans un premier temps le fichier XML non trié, et je le trie (ca ca fonctionne bien) je récupère donc un fichier xml trié dans le bon ordre :
    1) Par entité
    2) Par Service
    3) Par nom
    alors tu peux largement simplifier avec ce code :
    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
     
    <?xml version="1.0" encoding="utf-8"?>
     
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
     
       <xsl:output method="html" encoding="utf-8"/>
       <xsl:template match="/">
          <html>
             <body>
                <table border="1">
                   <xsl:apply-templates select="racine/PERSONNE" />
                </table>
             </body>
          </html>
       </xsl:template>
     
       <xsl:template match="PERSONNE">
    	<!-- ON TEST LA RUPTURE SUR L'ENTITE -->
            <xsl:if test="not(ENTITE = preceding-sibling::PERSONNE/ENTITE)">
    	  <tr>
                <td><xsl:value-of select="ENTITE" /></td>
                <td />
                <td />
              </tr>
            </xsl:if>
    	<!-- ON TEST LA RUPTURE SUR LE SERVICE -->
            <!-- Attention on force la rupture si le test sur ENTITE est vrai -->
            <xsl:if test="not(SERVICE = preceding-sibling::PERSONNE/SERVICE) or not(ENTITE = preceding-sibling::PERSONNE/ENTITE)">
    	  <tr>
                <td />
                <td><xsl:value-of select="SERVICE" /></td>
                <td />
              </tr>
            </xsl:if>
    	<!-- ON IMPRIME LE NOM -->
    	<tr>
              <td />
              <td />
              <td><xsl:value-of select="NOM" /></td>
    	</tr>
       </xsl:template>
     
    </xsl:stylesheet>
    Bien entendu, je te laisse le soin de remplir les vides (ton code javascript, les styles...)

    En attendant, comme tu peux le voir, ton code est largement simplifier et sera plus facilement maintenable (tu l'expérimenteras en ajoutant le javascript, les style et en transformant les lignes de tableau en tableau...)

    A+

  6. #6
    Nouveau membre du Club
    Inscrit en
    Octobre 2002
    Messages
    74
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 74
    Points : 36
    Points
    36
    Par défaut
    Merci à tous je vais tester ca tt de suite !!!

  7. #7
    Nouveau membre du Club
    Inscrit en
    Octobre 2002
    Messages
    74
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 74
    Points : 36
    Points
    36
    Par défaut
    ca fonctionne c'est plus rapide que mon code ;-)

    Je viens d'apprendre que je dois rajouter un niveau de groupement à savoir SOCIETE

    donc le résultat devra être
    <SOCIETE>
    <ENTITE>
    <SERVICE>
    <PERSONNES>
    ....

    je repars de vos xslt.. donc je passe par un template c'est le + simple ??

  8. #8
    Membre régulier Avatar de agueffier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2002
    Messages : 93
    Points : 114
    Points
    114
    Par défaut
    Super si ça fonctionne... bon courage pour la suite...

    Ah et n'oublies pas de mettre "Résolu" sur ce post...

    A+

  9. #9
    Nouveau membre du Club
    Inscrit en
    Octobre 2002
    Messages
    74
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 74
    Points : 36
    Points
    36
    Par défaut
    en fait j'ai un peu de mal encore avec xsl... et je galere pour rajouter 1 niveau de groupement au niveau du champ SOCIETE... comme indiqué sur mon post au dessus...

  10. #10
    Membre régulier Avatar de agueffier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2002
    Messages : 93
    Points : 114
    Points
    114
    Par défaut
    Bonjour,

    ben, en gros tu n'as qu'à rajouter un :
    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
     
    <xsl:template match="PERSONNE">
       <!-- ON TEST LA RUPTURE SUR L'SOCIETE -->
            <xsl:if test="not(SOCIETE = preceding-sibling::PERSONNE/SOCIETE)">
         <tr>
                <td><xsl:value-of select="SOCIETE" /></td>
                <td />
                <td />
                <td />
              </tr>
            </xsl:if>
       <!-- ON TEST LA RUPTURE SUR L'ENTITE -->
            <xsl:if test="not(ENTITE = preceding-sibling::PERSONNE/ENTITE) or not(SOCIETE = preceding-sibling::PERSONNE/SOCIETE)">
         <tr>
                <td />
                <td><xsl:value-of select="ENTITE" /></td>
                <td />
                <td />
              </tr>
            </xsl:if>
       <!-- ON TEST LA RUPTURE SUR LE SERVICE -->
            <!-- Attention on force la rupture si le test sur ENTITE est vrai -->
            <xsl:if test="not(SERVICE = preceding-sibling::PERSONNE/SERVICE) or not(ENTITE = preceding-sibling::PERSONNE/ENTITE) or not(SOCIETE = preceding-sibling::PERSONNE/SOCIETE)">
         <tr>
                <td />
                <td />
                <td><xsl:value-of select="SERVICE" /></td>
                <td />
              </tr>
            </xsl:if>
       <!-- ON IMPRIME LE NOM -->
       <tr>
              <td />
              <td />
              <td />
              <td><xsl:value-of select="NOM" /></td>
       </tr>
       </xsl:template>
    Normalement, cela devrait aller... sauf si ton XML n'est pas préalablement trié sur SOCIETE/ENTITE/SERVICE/NOM

    A+

Discussions similaires

  1. Problème de Tri
    Par darkian dans le forum Langage SQL
    Réponses: 5
    Dernier message: 02/01/2006, 14h39
  2. [MySQL] Problème de tri
    Par pounie dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 22/10/2005, 13h09
  3. Problème de tri avec analyse croisée
    Par drthodt dans le forum Access
    Réponses: 2
    Dernier message: 18/10/2005, 16h23
  4. [TToolBar] Problème de tri
    Par titiyo dans le forum Composants VCL
    Réponses: 6
    Dernier message: 01/09/2004, 09h21
  5. [Collections] Problème de tri
    Par feti2004 dans le forum Collection et Stream
    Réponses: 16
    Dernier message: 03/08/2004, 16h45

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