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 :

Calcul d'une quantité de licence récursivement


Sujet :

XSL/XSLT/XPATH XML

  1. #1
    Membre à l'essai
    Inscrit en
    Février 2010
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 33
    Points : 15
    Points
    15
    Par défaut Calcul d'une quantité de licence récursivement
    Bonjour alors voilà mon problème un XSL me permet de générer un tableau à partir d'un fichier XML

    le tableau obtenu est de la forme suivante :

    Code Article Désignation Quantité
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-HPUX CS for HP-UX 9
    VT-CS-HPUX CS for HP-UX 2
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-HPUX CS for HP-UX 3
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-HPUX CS for HP-UX 5
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-HPUX CS for HP-UX 1
    VT-CS-ILIN CS for Intel LINUX 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 2
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 3
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 2
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 2
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 3
    VT-CS-WNT CS for Windows NT/2000 2
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 2
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 1
    VT-CS-WNT CS for Windows NT/2000 2
    VT-CS-WNT CS for Windows NT/2000 4
    VT-CS-WNT CS for Windows NT/2000 2
    VT-SDS-HPUX SDS for HP-UX 1
    VT-SDS-HPUX SDS for HP-UX 1
    VT-SDS-HPUX SDS for HP-UX 1
    VT-XVI-HPUX XVI for HP-UX 1
    VT-XVI-WNT XVI for Windows NT 1
    VT-XVI-WNT XVI for Windows NT 1


    Voila le XSL correspondant
    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
    <?xml version="1.0" encoding="ISO-8859-1"?>
     
    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
    <xsl:output encoding="ISO-8859-1" method="html"/>
     
    	<xsl:param name="entreprise" />
    	<xsl:param name="site" />
     
    	<xsl:template match="Synthese">
    		<table width="100%" border="0" cellspacing="2" cellpadding="0">
    				<tr style="background-color:#e8e8e8" >
    					<td width="33%"><b>Code Article</b></td>
    					<td width="33%"><b>Désignation</b></td>
    					<td width="33%"><b>Quantité </b></td>
    				</tr>	
    		</table>
    		<table width="100%" border="1" bordercolor="#e8e8e8" cellspacing="0" cellpadding="0">
    		<xsl:for-each select="Record">
    			<xsl:choose>
    				<xsl:when test="./CpyTrdNamDsc=$entreprise and ./CpyAddrExCde=$site">
    					<tr>
    						<td width="25%"><xsl:value-of select="ObjExCde"/></td>
    						<td width="25%"><xsl:value-of select="ObjDsc"/></td>
    						<td width="25%"><xsl:value-of select="DosQtyVal"/></td>
     
     
     
    					</tr>	
    				</xsl:when>
    			</xsl:choose>
     
    		</xsl:for-each>
    		</table>
    	</xsl:template>
    </xsl:stylesheet>


    et un bout du XML

    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
    <Record>
      <CpyTrdNamDsc><![CDATA[SANOFI WINTHROP INDUSTRIE]]></CpyTrdNamDsc>
      <CpyAddrExCde><![CDATA[QUETIGNY]]></CpyAddrExCde>
      <ObjExCde><![CDATA[VT-CS-HPUX]]></ObjExCde>
      <ObjDsc><![CDATA[CS for HP-UX]]></ObjDsc>
      <DosQtyVal>2</DosQtyVal>
      <CntExCde><![CDATA[050701.01]]></CntExCde>
      <CpyInCde>1318</CpyInCde>
     </Record>
     <Record>
      <CpyTrdNamDsc><![CDATA[SANOFI WINTHROP INDUSTRIE]]></CpyTrdNamDsc>
      <CpyAddrExCde><![CDATA[AMBARES]]></CpyAddrExCde>
      <ObjExCde><![CDATA[VT-CS-HPUX]]></ObjExCde>
      <ObjDsc><![CDATA[CS for HP-UX]]></ObjDsc>
      <DosQtyVal>1</DosQtyVal>
      <CntExCde><![CDATA[Crt SHRR080728.01+Avt n°1]]></CntExCde>
      <CpyInCde>1318</CpyInCde>
     </Record>
     <Record>
      <CpyTrdNamDsc><![CDATA[SANOFI WINTHROP INDUSTRIE]]></CpyTrdNamDsc>
      <CpyAddrExCde><![CDATA[AMBARES]]></CpyAddrExCde>
      <ObjExCde><![CDATA[VT-CS-HPUX]]></ObjExCde>
      <ObjDsc><![CDATA[CS for HP-UX]]></ObjDsc>
      <DosQtyVal>9</DosQtyVal>
      <CntExCde><![CDATA[Crt SHRR080728.01+Avt n°1]]></CntExCde>
      <CpyInCde>1318</CpyInCde>
     </Record>
     <Record>
      <CpyTrdNamDsc><![CDATA[SANOFI WINTHROP INDUSTRIE]]></CpyTrdNamDsc>
      <CpyAddrExCde><![CDATA[CHILLY MAZARIN]]></CpyAddrExCde>
      <ObjExCde><![CDATA[VT-CS-HPUX]]></ObjExCde>
      <ObjDsc><![CDATA[CS for HP-UX]]></ObjDsc>
      <DosQtyVal>1</DosQtyVal>
      <CntExCde><![CDATA[050601.03]]></CntExCde>
      <CpyInCde>1318</CpyInCde>
     </Record>
     <Record>
      <CpyTrdNamDsc><![CDATA[SANOFI WINTHROP INDUSTRIE]]></CpyTrdNamDsc>
      <CpyAddrExCde><![CDATA[MONTARGIS2]]></CpyAddrExCde>
      <ObjExCde><![CDATA[VT-CS-HPUX]]></ObjExCde>
      <ObjDsc><![CDATA[CS for HP-UX]]></ObjDsc>
      <DosQtyVal>2</DosQtyVal>
      <CntExCde><![CDATA[PC.SH070327.01(crt n°SHRR060427.01)]]></CntExCde>
      <CpyInCde>1318</CpyInCde>
    Mon but étant d'ajouter une 4ème colonne pour sommer les quantité de licence en fonction du code article.

    J'ai bien essayer un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <td width="25%"><xsl:value-of select="sum(preceding::DosQtyVal[../ObjExCde=current()/ObjExCde]|DosQtyVal)"/></td>
    mais avec le <xsl:for-each select="Record"> ca marche pas bien du tout la somme récursive :/

    Quelqu'un aurait une idée ?

  2. #2
    Membre à l'essai
    Inscrit en
    Février 2010
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 33
    Points : 15
    Points
    15
    Par défaut
    Problème résolu en enlevant certaines données du XML et plus eu besoin de modifier le XSL

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

Discussions similaires

  1. [Débutant] Diminuer la quantité de calculs dans une modélisation
    Par kolihty dans le forum MATLAB
    Réponses: 2
    Dernier message: 16/05/2010, 22h23
  2. Réponses: 6
    Dernier message: 10/01/2009, 21h18
  3. Calcul d'une quantité par heure
    Par orzra dans le forum C#
    Réponses: 6
    Dernier message: 12/06/2007, 13h28
  4. [SUM] récuperer une quantite a partir de plusieurs table
    Par Snowballz dans le forum PostgreSQL
    Réponses: 9
    Dernier message: 14/09/2004, 18h48
  5. calcul dans une requête
    Par blaz dans le forum Langage SQL
    Réponses: 8
    Dernier message: 22/12/2003, 10h31

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