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 :

[XSLT] generer un fichier xml optmise d'un autre fichier xml


Sujet :

XSL/XSLT/XPATH XML

  1. #1
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut [XSLT] generer un fichier xml optmise d'un autre fichier xml
    bonjour tout le monde,

    c'est pas la 1ere fois que je travaille sur xml et xslt mais je ne sais quoi faire.

    j'ai un fichier xml que je connais pas le contenu(le programme dois marcher sur n'importe quel fichier xml) que je dois trier avec une feuille xslt( je connais seulement la balise sur laquel je dois effectuer mon tri)
    en sortie je dois avoir un fichier xml trier.

    et ca je ne sais pas comment le faire

    Merci de votre aide,

  2. #2
    Membre à l'essai
    Inscrit en
    Décembre 2007
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 20
    Points : 24
    Points
    24
    Par défaut
    vous trouverez des sources pour la recopie/modifications ici:
    http://xml.developpez.com/sources/?page=modifs

    Pour le tri c'est un usage de la balise xsl:sort qui est nécessaire, mais pour savoir ou et comment la placer il faudrait un peu + d'infos

  3. #3
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut un peu avance mais toujours des problèmes
    merci beaucoup pour ton aide,

    j'ai reussi a faire mes filtres et mes tris mais j'ai un autre problème un peu banale

    je veux que le nom de la balise et l'ordre de tri passe en parametre( je veux les recuperer a partir d'un fichier php) mais a chaque fois je declare un parametre il me donne une erreur que j'arrive pas à la corriger)

    voila mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    	<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
    	<xsl:template match="/">
    		<xsl:param name="order" select="ascending"/>
    		<xsl:for-each select="Document/Etudiant" >
    			<xsl:sort select="nom" data-type="text" order="$order"/>
    			<xsl:value-of select="."/>
    		</xsl:for-each>
    	</xsl:template>
    </xsl:stylesheet>
    et voilà l'erreur qui m'affiche:

    La valeur de l'attribut « order » peut être uniquement « ascending » ou « descending ».

    merci d'avance pour votre aide

  4. #4
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    Faudrait voir ton xml de données source pour être sûr de ce qui ce passe, mais tu peux déja mettre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:sort select="nom" data-type="text" order="{$order}"/>

  5. #5
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:param name="order" select="ascending"/>
    ça me semble très louche.
    Si ton param est global à la transformation xsl-t il n'y a pas de 'select' et le noeud devrait être plutôt comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <xsl:stylesheet version="1.0" xmlnssl="http://www.w3.org/1999/XSL/Transform">
    <xsl:param name="order"/>
    ....
    D'ailleurs il y a jamais de 'select' pour les 'param' seulement les 'variable'.

  6. #6
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut
    Merci Morbo pour ta réponse,

    j'ai teste ce que tu m'as dit mais j'ai toujours des messages d'erreur qui s'affichent.
    voila mon fichier xslt:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    <?xml version="1.0" encoding="UTF-8"?>'
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    	<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
    	<xsl:template match="/">
    		<xsl:param name="order"/>
    		<xsl:for-each select="Document/Etudiant" >
    			<xsl:sort select="nom" data-type="text" order="$order"/>
    			<xsl:value-of select="."/>
    		</xsl:for-each>
    	</xsl:template>
    </xsl:stylesheet>
    et voila le fichier php:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    <?php
    	$fichierXML="fichierXML.xml";
        $fichierXSLT="tri.xsl";
    	$xml=DomDocument::load($fichierXML);
        $xslt = new XSLTProcessor();
    	$xslt->importStylesheet(DOMDocument::load($fichierXSLT));
        //$xslt_params["order"] ="descending";
        $xslt->setParameter( NULL, 'order' ,'descending');
    	echo $xslt->transformToXML($xml);
     
    ?>

  7. #7
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    Quels messages d'erreur?
    Sinon, t'as pas tellement modifié le xsl d'origine...
    Je mettrais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <?xml version="1.0" encoding="UTF-8"?>'
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:param name="order"/>
    	<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
    	<xsl:template match="/">
    		<xsl:for-each select="Document/Etudiant" >
    			<xsl:sort select="nom" data-type="text" order="{$order}"/>
    			<xsl:value-of select="."/>
    		</xsl:for-each>
    	</xsl:template>
    </xsl:stylesheet>

  8. #8
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut
    j'ai mis le meme code que tu m'a envoye mais rien ne s'affiche il me donne que les warning suivants:

    Warning: DOMDocument::load() [function.DOMDocument-load]: Start tag expected, '<' not found in file:///C%3A/Program%20Files/EasyPHP%202.0b1/www/tri.xsl, line: 1 in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 6

    Warning: XSLTProcessor::importStylesheet() expects parameter 1 to be object, boolean given in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 6

    Warning: XSLTProcessor::transformToXml() [function.XSLTProcessor-transformToXml]: No stylesheet associated to this object in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 9

    je comprend pas pq il affiche rien

  9. #9
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    J'ai fait une typo en copiant/collant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <?xml version="1.0" encoding="UTF-8"?>'
    :p vire la quote.
    Remarque que c'est ce qu'il dit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Start tag expected, '<' not found

  10. #10
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut
    merci beaucoup,
    je savais que c'est une erreur banale

    mais j'ai une autre question

    comment faire pour appliquer une autre feuille de style sur le fichier resultat?

    et désolé pour le dérangement (je travaille sur un projet que je dois rendre demain c'est pour ca je suis tres perturbée)

    merci beaucoup pr ton aide

  11. #11
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut
    Marbooooooooo,
    j'ai toujours les messages d'erreurs qui s'affichent
    j'ai essaye de récupérer tout les paramètres du fichier php mais pleins d'erreur qui s'affichent

    voila mon fichier xsl:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    	<xsl:param name="order"/>
    	<xsl:param name="nomBalise"/>
        <xsl:param name="chemin"/>
        <xsl:param name="type"/>
    	<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
    	<xsl:template match="/">
    		<xsl:for-each select="{$chemin}" >
    			<xsl:sort select="{$nomBalise}" data-type="{$type}" order="{$order}"/>
    			<xsl:value-of select="."/>
    		</xsl:for-each>
    	</xsl:template>
    </xsl:stylesheet>
    et voila le fichier php:
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <?php
    	$fichierXML="fichierXML.xml";
        $fichierXSLT="tri.xsl";
    	$xml=DomDocument::load($fichierXML);
        $xslt = new XSLTProcessor();
    	$xslt->importStylesheet(DOMDocument::load($fichierXSLT));
        //$xslt_params["order"] ="descending";
        $xslt->setParameter( NULL, 'order' ,"ascending");
        $xslt->setParameter( NULL, 'nomBalise' ,"nom");
    	$xslt->setParameter( NULL, 'chemin' ,"Document/Etudiant");
    	$xslt->setParameter( NULL, 'type' ,"text");
    	echo $xslt->transformToXML($xml);
    ?>

    et voila les erreurs qui me donnent:
    Warning: XSLTProcessor::importStylesheet() [function.XSLTProcessor-importStylesheet]: Invalid expression in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 6

    Warning: XSLTProcessor::importStylesheet() [function.XSLTProcessor-importStylesheet]: compilation error: file file:///C%3A/Program%20Files/EasyPHP%202.0b1/www/tri.xsl line 9 element for-each in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 6

    Warning: XSLTProcessor::importStylesheet() [function.XSLTProcessor-importStylesheet]: xsl:for-each : could not compile select expression '{$chemin}' in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 6

    Warning: XSLTProcessor::importStylesheet() [function.XSLTProcessor-importStylesheet]: Invalid expression in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 6

    Warning: XSLTProcessor::importStylesheet() [function.XSLTProcessor-importStylesheet]: compilation error: file file:///C%3A/Program%20Files/EasyPHP%202.0b1/www/tri.xsl line 10 element sort in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 6

    Warning: XSLTProcessor::importStylesheet() [function.XSLTProcessor-importStylesheet]: xsltSortComp: could not compile select expression '{$nomBalise}' in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 6

    Warning: XSLTProcessor::transformToXml() [function.XSLTProcessor-transformToXml]: No stylesheet associated to this object in C:\Program Files\EasyPHP 2.0b1\www\filtre.php on line 12
    je ne comprends rien aide moi stp

  12. #12
    Membre éprouvé Avatar de alain.couthures
    Profil pro
    Gérant
    Inscrit en
    Avril 2007
    Messages
    902
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Gérant

    Informations forums :
    Inscription : Avril 2007
    Messages : 902
    Points : 1 247
    Points
    1 247
    Par défaut
    Mon point de vue est que l'on ne peut pas faire cela en une seule transformation !

    L'utilisation des {} est, pour moi, réservée à la construction d'attributs du XML résultat pas au paramétrage de la feuille de style...

    Il faudrait construire d'abord la feuille de style au moyen d'une première transformation puis, ensuite, appliquer ce résultat au XML initial.
    Formulaires XForms sur tous navigateurs sans extension à installer (architecture XRX) : http://www.agencexml.com/xsltforms/

  13. #13
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    Ben les chemins xpath qui valorisent les attributs ne peuvent être contruit dynamiquement (select="$chemin", avec ou sans accolades passera jamais).
    Par contre quelque chose de se type la peut fonctionner mais avec de mauvaises performances.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <xsl:param name="order"/>
        <xsl:param name="nomBalise"/>
        <xsl:param name="chemin"/>
        <xsl:param name="type"/>
     
        <xsl:for-each select="//*[name()=$chemin]" >
        <xsl:sort select="*[name()=$nomBalise]" data-type="{$type}" order="{$order}"/>
          <xsl:copy-of select="."/>
        </xsl:for-each>
    Sachant que j'ai valorisé 'nomBalise' par 'nom' et 'chemin' par 'Etudiant'.
    Et mon xml source étant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <?xml version="1.0" encoding="ISO-8859-1"?>
    <Document>
      <Etudiant><nom>pierre</nom></Etudiant>
      <Etudiant><nom>paul</nom></Etudiant>
      <Etudiant><nom>jacques</nom></Etudiant>
      <Etudiant><nom>marc</nom></Etudiant>
    </Document>

  14. #14
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut
    j'ai essaye ta solution marbo,
    mais il donne rien ni erreurs ni resultat
    il affiche rien

  15. #15
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    Tu peux faire voir ton nouveau xsl & php?

  16. #16
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut
    le fichier xsl:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    	<xsl:param name="order"/>
    	<xsl:param name="nomBalise"/>
        <xsl:param name="chemin"/>
        <xsl:param name="type"/>
    	<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
    	<xsl:template match="/">
    		<xsl:for-each select="//*[name()=$chemin]"  >
    			<xsl:sort select="*[name()=$nomBalise]" data-type="{$type}" order="{$order}"/>
    			<xsl:value-of select="."/>
    		</xsl:for-each>
    	</xsl:template>
    </xsl:stylesheet>
    et php:
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <?php
    	$fichierXML="fichierXML.xml";
        $fichierXSLT="tri.xsl";
    	$xml=DomDocument::load($fichierXML);
        $xslt = new XSLTProcessor();
    	$xslt->importStylesheet(DOMDocument::load($fichierXSLT));
        //$xslt_params["order"] ="descending";
        $xslt->setParameter( NULL, 'order' ,"ascending");
        $xslt->setParameter( NULL, 'nomBalise' ,"nom");
    	$xslt->setParameter( NULL, 'chemin' ,"Document/Etudiant");
    	$xslt->setParameter( NULL, 'type' ,"text");
    	echo $xslt->transformToXML($xml);
    ?>

  17. #17
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:value-of select="."/>
    devient
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <xsl:copy-of select="."/>
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $xslt->setParameter( NULL, 'chemin' ,"Document/Etudiant");
    devient
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $xslt->setParameter( NULL, 'chemin' ,"Etudiant");

  18. #18
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut
    merciiiiiiiiiiiiiiiiiiiiiiiiiiiiiii Marbo,

    ca marche tres bien

    encore une derniere question

    si je veux appliquer un autre fichier XSLT ( qui donne le format d'affichage)sur le fichier xml resultat(xml trié), comment je peux le faire?

  19. #19
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 466
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 466
    Points : 1 610
    Points
    1 610
    Par défaut
    C'est Morbo ma chère moguie :p,
    Sinon je connais très peu le php, pour t'aider, mais c'est possible.
    Si tu regardes le forum http://www.developpez.net/forums/forumdisplay.php?f=611 tu trouveras peut être sinon demande.
    Bonne journée.

  20. #20
    Membre à l'essai
    Inscrit en
    Juin 2006
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 31
    Points : 13
    Points
    13
    Par défaut
    désolé Morbo
    c'etait une erreur de frappe

    et merci beaucoup pr ton aide, je vais aller voir dans ce forum

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Réponses: 1
    Dernier message: 28/02/2012, 18h30
  2. [DOM] Reconstruire un fichier XML à partir d'un autre fichier XML
    Par Jonvols dans le forum Format d'échange (XML, JSON...)
    Réponses: 12
    Dernier message: 13/11/2010, 01h49
  3. Réponses: 5
    Dernier message: 23/03/2009, 16h36
  4. Réponses: 2
    Dernier message: 14/05/2007, 10h22
  5. [FPDF] Créer un fichier PDF à partir d'un autre fichier PDF
    Par axel-erator dans le forum Bibliothèques et frameworks
    Réponses: 5
    Dernier message: 18/06/2006, 23h29

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