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

Langage PHP Discussion :

Export CSV d'une requête SQL


Sujet :

Langage PHP

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 11
    Points : 8
    Points
    8
    Par défaut Export CSV d'une requête SQL
    Bonjour, voici mon problème.
    J'ai sur une page le résultat d'une requête m'affichant au fur et à mesure des lignes.
    Je souhaiterais pouvoir exporter l'ensemble des lignes dans un fichier excel (csv).
    Le problème, c'est que je ne sais pas où placer le code permettant l'export.
    Si je place le bouton Export après le "While" de ma requête, ça ne m'exporte que la dernière ligne.
    Si je place le code dans le "while", ca me crée autant de boutons Export qu'il n'y a de lignes, et chaque bouton ne peut donc exporter qu'une ligne.

    Voici le bout de code de la page requête :

    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
    $exe_req_prod_id = mysql_query($req_prod_id) or die(mysql_error());
    while($res_prod_id = mysql_fetch_array($exe_req_prod_id)){
    	$formation = $res_prod_id['product_sku'];
    
            echo '<tr class="liste">';
    	echo"<td>".$date."</td><td>".$formation."</td><td>".$theme."</td><td>".$prix."</td><td>".$repas."</td><td>".$nom."</td><td>".$prenom."</td>";
    	echo "</tr>";
    }
    	echo "<a href=\"test.php?titre=".$titre."&nom=".$nom."&prenom=".$prenom."&adresse1=".$adresse1."&adresse2=".$adresse2."&code_postal=".$code_postal."&ville=".$ville."&tel=".$tel."&fax=".$fax."&email=".$email."&theme=".$theme."&formation=".$formation."&prix=".$prix."&repas=".$repas."\"><input type=\"submit\" value=\"Exporter\"></a>";
    }				
    ?>
    
    Page test.php = page sur laquelle renvoie le bouton Exporter
    
    $fichier = new FichierExcel();
    $fichier->Colonne("Titre;Nom;Prenom;Adresse1;Adresse2"...)
    $fichier->Insertion("'".$titre."';'".$nom."';'".$prenom."'....)
    */
    $fichier->output('NomFichier'); 
    
    Page Création Fichier Excel
    class FichierExcel {	
    private 
    	$csv = Null;
    function Insertion($file){
    
    		$this->csv.=$file."\n";
    		return $this->csv;
    	}
    function output($NomFichier){
    	
    		header("Content-type: application/vnd.ms-excel");
    		header("Content-disposition: attachment; filename=$NomFichier.csv");
    		header("Content-type: NAMES 'utf8'");
    
    		print $this->csv;
    		exit;
    	}   }?>
    Je suis bloqué depuis un bon moment sans trouver d'issue..
    j'ai bien pensé à placer le début de ma page test dans ma boucle "while"
    mais ca ne fonctionne pas.
    Merci d'avance de votre aide...

  2. #2
    Membre du Club Avatar de spin0us
    Profil pro
    Inscrit en
    Février 2003
    Messages
    87
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Février 2003
    Messages : 87
    Points : 64
    Points
    64
    Par défaut
    Tu ajoutes un lien d'export ou tu le souhaites avec param en POST ou en GET.
    Puis dans ton code tu traites ce param avant de comment ton affichage. Si l'export est demandé, tu fais un truc genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    if(isset($_GET['export']) && $_GET['export'] == 'csv') {
    $output = "";
    $exe_req_prod_id = mysql_query($req_prod_id) or die(mysql_error());
    while($res_prod_id = mysql_fetch_array($exe_req_prod_id)){
    $formation = $res_prod_id['product_sku'];
    $output .= "$date;$formation;$theme;$prix;$repas;$nom;$prenom\n";
    }
    header("Content-type: application/vnd.ms-excel");
    header("Content-disposition: attachment; filename=$NomFichier.csv");
    header("Content-type: NAMES 'utf8'");
    echo $output;
    die();
    }

Discussions similaires

  1. Génération fichier .csv via une requête SQL
    Par matnys dans le forum Import/Export
    Réponses: 5
    Dernier message: 12/12/2011, 22h03
  2. Export CSV à partir d'une requête SQL(VB.Net)
    Par bestcasaoui dans le forum VB.NET
    Réponses: 3
    Dernier message: 11/01/2011, 16h51
  3. [MySQL] Export CSV d'une requête par un bouton
    Par siuol77 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 08/07/2010, 13h24
  4. Export CSV à partir d'une requête SQL
    Par neimad31 dans le forum VBA Access
    Réponses: 5
    Dernier message: 26/08/2009, 13h10
  5. export/import d'une requête sql
    Par amine2010 dans le forum SQL
    Réponses: 1
    Dernier message: 17/08/2009, 15h30

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