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 :

XML TO CSV via récursion ?


Sujet :

XSL/XSLT/XPATH XML

  1. #1
    Membre averti
    Homme Profil pro
    IES
    Inscrit en
    Décembre 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : IES
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2012
    Messages : 10
    Par défaut XML TO CSV via récursion ?
    Bonjour à tous,

    Alors voila je vous expose mon problème.

    Je dois transformer un fichier XML en fichier CSV via le langage XSLT

    Or certains Noeuds peuvent être répété n fois.

    J'utilise donc une récursion pour parcourir mon arbre et avoir un fichier CSV complet en sortie.

    Cela fonctionne mais le soucis est que cette récursion est beaucoup trop gourmande en temps de traitement, je voulais donc savoir si vous aviez quelques pistes de réflexions à me proposer.

    Voici le code que j'utilise actuellement :

    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 name="repeatAffichebalise">
        <!-- Nombre de répétitions voulues -->
        <xsl:param name="repeatNum"/>
     
         <!-- Condition de non-arrêt de la récursion -->
            <xsl:if test="count(//ns0:adminFile)>$repeatNum">
     
        <AfficheBalise>
    	<xsl:for-each select="ns0:file/ns0:emp_set/ns0:emp">
          <xsl:value-of select="ns0:adminData/ns0:adminFile_set/ns0:adminFile[repeatNum]/ns0:adminDataType"/>
    	  <xsl:text>";"</xsl:text>
          <xsl:value-of select="ns0:adminData/ns0:adminFile_set/ns0:adminFile[repeatNum]/ns0:cntrct/ns0:empCtgr"/>
    	  <xsl:text>";"</xsl:text>
     
    	 </xsl:for-each>
       </AfficheBalise>
     
          <!-- Appeler la récursion suivante -->
          <xsl:call-template name="repeatAffichebalise">
            <xsl:with-param name="repeatNum" select="$repeatNum + 1"/>
          </xsl:call-template>
        </xsl:if>
     
      </xsl:template>
     
        <!-- Parcours de l'arbre XML -->
     
    <xsl:template match="/">
     
     
          <!-- Appel de la procédure récursive -->
          <xsl:call-template name="repeatAffichebalise">
            <xsl:with-param name="repeatNum" select="'0'"/>
          </xsl:call-template>
     
    </xsl:template>

    Merci par avance !

  2. #2
    Membre Expert
    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
    Par défaut
    Tu pourrais passer par une variable et du coup ne faire le traitement qu'une fois :
    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
    <xsl:template ...>
      <xsl:variable name="csv_line">
        <!-- le traitement à faire pour afficher l'élément actuel -->
        <AfficheBalise>
          <xsl:for-each select="ns0:file/ns0:emp_set/ns0:emp">
            <xsl:value-of select="ns0:adminData/ns0:adminFile_set/ns0:adminFile[repeatNum]/ns0:adminDataType"/>
            <xsl:text>";"</xsl:text>
            <xsl:value-of select="ns0:adminData/ns0:adminFile_set/ns0:adminFile[repeatNum]/ns0:cntrct/ns0:empCtgr"/>
            <xsl:text>";"</xsl:text>
          </xsl:for-each>
        </AfficheBalise>
      </xsl:variable>
     
      <xsl:call-template name="repeatAffichebalise">
        <xsl:with-param name="max_iter" select="count(//ns0:adminFile)"/>
        <xsl:with-param name="csv_line" select="$csv_line"/>
      </xsl:call-template>
    </xsl:template>
     
    <xsl:template name="repeatAfficheLigne">
      <!-- variable d'iteration -->
      <xsl:param name="iterator" select="'0'"/>
      <!-- Nombre de répétitions voulues -->
      <xsl:param name="max_iter"/>
      <!-- Ligne à afficher -->
      <xsl:param name="csv_line"/>
     
      <!-- Condition de passage dans le traitement -->
      <xsl:if test="$max_iter > $repeatNum">
        <xsl:value-of select="$csv_line"/>
     
        <!-- Appel de la récursion suivante -->
        <xsl:call-template name="repeatAffichebalise">
          <xsl:with-param name="iterator" select="$iterator + 1"/>
          <xsl:with-param name="max_iter" select="$max_iter"/>
          <xsl:with-param name="csv_line" select="$csv_line"/>
        </xsl:call-template>
      </xsl:if>
    </xsl:template>

Discussions similaires

  1. xml vers csv via xsl pur
    Par tofpad dans le forum XSL/XSLT/XPATH
    Réponses: 4
    Dernier message: 17/03/2010, 09h35
  2. [xml]Conversion d'une structure xml en csv
    Par cchatel2000 dans le forum XML/XSL et SOAP
    Réponses: 3
    Dernier message: 01/08/2005, 16h00
  3. [XML][XSLT] transformer le xml en binaire via une xslt
    Par chama dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 25/07/2005, 11h42
  4. [DOM] En java comment charger un XML en dynamique via un filtre
    Par fbertoux dans le forum Format d'échange (XML, JSON...)
    Réponses: 2
    Dernier message: 16/12/2004, 18h35
  5. Transformation xml + xsl -> HTML via PHP
    Par petit-ourson dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 19/10/2003, 22h42

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