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 :

Trier par mois et faire une somme [XSLT 1.0]


Sujet :

XSL/XSLT/XPATH XML

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

    Informations forums :
    Inscription : Septembre 2008
    Messages : 12
    Points : 7
    Points
    7
    Par défaut Trier par mois et faire une somme
    Bonjour,

    Comme l'indique mon titre je cherche à trier différents noeuds par mois et sommer certaines valeurs.

    Un exemple sera plus parlant

    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
    84
    85
    86
    87
    88
    89
    90
    91
    92
     
    <?xml version="1.0" encoding="ibm437" standalone="yes"?>
    <Centrale>
      <DayInfo Date="2011-11-01T00:00:00">   
         <Familles>
          <Famille Tp="0" Name="Toto" Id="385F13">
            <Ttc>0</Ttc>
            <Ht>0</Ht>
            <Bu>0</Bu>
            <Qt>0</Qt>
          </Famille>
          <Famille Tp="0" Name="Tata" Id="385F11">
            <Ttc>0</Ttc>
            <Ht>0</Ht>
            <Bu>0</Bu>
            <Qt>0</Qt>
          </Famille>
          <Famille Tp="0" Name="Titi" Id="385F9">
            <Ttc>-4000</Ttc>
            <Ht>-4000</Ht>
            <Bu>0</Bu>
            <Qt>-2</Qt>
          </Famille>
        </Familles>
      </DayInfo>
      <DayInfo Date="2011-11-02T00:00:00">
        <Closure />
        <Familles>
          <Famille Tp="0" Name="Toto" Id="385F13">
            <Ttc>0</Ttc>
            <Ht>0</Ht>
            <Bu>0</Bu>
            <Qt>0</Qt>
          </Famille>
          <Famille Tp="0" Name="Tata" Id="385F11">
            <Ttc>0</Ttc>
            <Ht>0</Ht>
            <Bu>0</Bu>
            <Qt>0</Qt>
          </Famille>
     <Famille Tp="0" Name="Titi" Id="385F9">
            <Ttc>-4000</Ttc>
            <Ht>-4000</Ht>
            <Bu>0</Bu>
            <Qt>-2</Qt>
          </Famille>
      </DayInfo>
    <DayInfo Date="2011-12-01T00:00:00">   
         <Familles>
          <Famille Tp="0" Name="Toto" Id="385F13">
            <Ttc>0</Ttc>
            <Ht>0</Ht>
            <Bu>0</Bu>
            <Qt>0</Qt>
          </Famille>
          <Famille Tp="0" Name="Tata" Id="385F11">
            <Ttc>0</Ttc>
            <Ht>0</Ht>
            <Bu>0</Bu>
            <Qt>0</Qt>
          </Famille>
          <Famille Tp="0" Name="Titi" Id="385F9">
            <Ttc>-4000</Ttc>
            <Ht>-4000</Ht>
            <Bu>0</Bu>
            <Qt>-2</Qt>
          </Famille>
        </Familles>
      </DayInfo>
    <DayInfo Date="2011-12-02T00:00:00">
        <Closure />
        <Familles>
          <Famille Tp="0" Name="Toto" Id="385F13">
            <Ttc>0</Ttc>
            <Ht>0</Ht>
            <Bu>0</Bu>
            <Qt>0</Qt>
          </Famille>
          <Famille Tp="0" Name="Tata" Id="385F11">
            <Ttc>0</Ttc>
            <Ht>0</Ht>
            <Bu>0</Bu>
            <Qt>0</Qt>
          </Famille>
     <Famille Tp="0" Name="Titi" Id="385F9">
            <Ttc>-4000</Ttc>
            <Ht>-4000</Ht>
            <Bu>0</Bu>
            <Qt>-2</Qt>
          </Famille>
      </DayInfo>
     </Centrale>
    Donc ce que j'aimerais c'est faire une somme de tout les articles "Toto" pour le mois de novembre ainsi que pour "Tata" et "Titi" puis on recommence pour décembre et ainsi de suite.

    J'ai lu quelques articles sur "xsl:sort" mais comment puis je faire quelque chose de générique pour que le tri se fasse automatiquement et que je ne somme que les articles par mois. Les "Id" sont propres à chaque article donc si besoin je peux les spécifier.

    Merci d'avance.

  2. #2
    Expert confirmé
    Avatar de Loceka
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    2 276
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 2 276
    Points : 4 843
    Points
    4 843
    Par défaut
    En XSL 1.0 ce n'est pas super simple. mais quand même faisable :

    Tu peux utiliser la méthode de Muench (cf FAQ ou google) pour regrouper les entrées par mois :
    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
    <!-- déclaration des clés à utiliser -->
    <xsl:key name="mois" match="DayInfo" use="substring-before(substring-after(@Date, '-'), '-')"/>
    <xsl:key name="famille" match="Famille" use="@Id"/>
    <!-- ... -->
    <!-- Méthode de muench sur les mois -->
    <xsl:for-each select="//DayInfo[generate-id(key('mois', substring-before(substring-after(@Date, '-'), '-'))) = generate-id(.)]">
    	<!-- tri par mois -->
    	<xsl:sort select="substring-before(substring-after(@Date, '-'), '-')"/>
    	<xsl:variable name="var_mois" select="substring-before(substring-after(@Date, '-'), '-')"/>
    	<xsl:value-of select="$var_mois"/>
    	<!-- méthode de Muench sur les familles -->
    	<xsl:for-each select="Familles/Famille[generate-id(key('famille', @Id)) = generate-id(.)]">
    		<!-- tri par nom de famille -->
    		<xsl:sort select="@Name"/>
    		<xsl:variable name="var_id" select="@Id"/>
    		<!-- affichage des données -->
    		<xsl:value-of select="@Name"/>
    		<xsl:value-of select="sum(//DayInfo[substring-before(substring-after(@Date, '-'), '-') = $var_mois]/Familles/Famille[@Id = $var_id]/Qt)">
    	</xsl:for-each>
    </xsl:for-each>

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    Merci d'avance à toi

    Edit
    Je fais un retour d'ici peu.

    Je suis entrain le tester

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

    Informations forums :
    Inscription : Septembre 2008
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    Je ne sais pas comment te remercier à part avec un GRAND MERCI

    J'ai encore beaucoup à apprendre en xsl et je t'avoue que je ne comprends pas tout dans ton code mais je vais le regarder de plus prêt pour mieux cerner ta logique et ces fonctions.

    Après différent test tout est ok et c'est opérationnel

    Il manquait un / à la fin du xsl:value

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:value-of select="sum(//DayInfo[substring-before(substring-after(@Date, '-'), '-') = $var_mois]/Familles/Famille[@Id = $var_id]/Qt)"/>
    Et pour que la répétition soit effective pour les autres mois il fallait ajouter // devant Familles :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:for-each select="//Familles/Famille[generate-id(key('famille', @Id)) = generate-id(.)]">
    Je pense que ce forum va être très instructif pour moi et c'est plaisant de voir qu'une personne prenne le temps d'aider en faisant un code propre et fonctionnel

  5. #5
    Expert confirmé
    Avatar de Loceka
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    2 276
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 2 276
    Points : 4 843
    Points
    4 843
    Par défaut
    Citation Envoyé par TiBen Voir le message
    pour que la répétition soit effective pour les autres mois il fallait ajouter // devant Familles :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:for-each select="//Familles/Famille[generate-id(key('famille', @Id)) = generate-id(.)]">
    Oui, j'ai remarqué ça aussi mais je ne comprends pas pourquoi, c'est totalement illogique. Si quelqu'un pouvait m'éclairer sur la question, je lui en saurai gré.

  6. #6
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 566
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 566
    Points : 21 635
    Points
    21 635
    Par défaut
    Citation Envoyé par Loceka Voir le message
    Oui, j'ai remarqué ça aussi mais je ne comprends pas pourquoi, c'est totalement illogique. Si quelqu'un pouvait m'éclairer sur la question, je lui en saurai gré.
    Ce for-each se situe sous un autre for-each qui sélectionne tous les <DayInfo> qui sont le premier <DayInfo> à avoir la date qu'il a.

    Donc, en faisant un for-each sur Familles et non pas //Familles, tu ne sélectionnes que les <Familles> qui sont sous ce premier <DayInfo>.
    Alors que ce qui nous intéresse, c'est toutes les Familles de tous les <DayInfo> afin de pouvoir identifier toutes les ids.

  7. #7
    Expert confirmé
    Avatar de Loceka
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    2 276
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 2 276
    Points : 4 843
    Points
    4 843
    Par défaut
    Oui, je suis d'accord que sur le principe c'était mal d'écrire ça. Mais dans les fait, comme chaque DayInfo contient toutes les familles, ça ne devrait rien changer au résultat.

    J'ai même essayé en écrivant ça et ça ne fonctionne pas (aucun résultat) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:for-each select="//DayInfo[substring-before(substring-after(@Date, '-'), '-') = $var_mois]/Familles/Famille[generate-id(key('famille', @Id)) = generate-id(.)]">
    Or pour moi ça devrait fonctionner (même si, là encore, ça ne sélectionne pas ce qu'on veut vraiment en théorie).

  8. #8
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 566
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 566
    Points : 21 635
    Points
    21 635
    Par défaut
    Citation Envoyé par Loceka Voir le message
    Oui, je suis d'accord que sur le principe c'était mal d'écrire ça. Mais dans les fait, comme chaque DayInfo contient toutes les familles, ça ne devrait rien changer au résultat.
    Il contient une Familles de chaque id... Mais pas forcément la première Familles de cet id, celle qui sera renvoyée par key() et dont on vérifie l'égalité du generate-id().

  9. #9
    Expert confirmé
    Avatar de Loceka
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    2 276
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 2 276
    Points : 4 843
    Points
    4 843
    Par défaut
    Ben là tout de suite je comprends mieux alors. ^_^

    Merci.

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

Discussions similaires

  1. Faire une somme par mois
    Par jouclar dans le forum Général Python
    Réponses: 5
    Dernier message: 09/10/2011, 14h08
  2. Réponses: 5
    Dernier message: 15/09/2008, 15h06
  3. faire une somme par semaine et par client
    Par zer35 dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 12/10/2007, 14h26
  4. [Conception] Faire une somme de valeurs définies par une boucle
    Par fixbraun dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 25/09/2006, 23h46
  5. faire une somme dans un état
    Par PAINCO dans le forum Access
    Réponses: 1
    Dernier message: 23/06/2005, 19h41

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