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

PHP & Base de données Discussion :

Exportation BDD vers csv [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2013
    Messages
    247
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2013
    Messages : 247
    Par défaut Exportation BDD vers csv
    Bonjour, j'essaie d'exporter ma table issue de ma BDD vers fichier csv. L'exportation des données se passe bien sauf que toutes les données exportées sont dans une seule colonne de la feuille excel.

    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
     
    		$csv_filename = 'liste-participant_'.date('d-m-Y').'.csv';
     
    		$sql = 'SELECT * FROM ma_table ORDER BY id';
    		$query = $connect_db->query($sql);
    		$query->setFetchMode(PDO::FETCH_ASSOC);
    		$count = 30;
     
    		$users = array();
    		if ($count > 0) {
    			while ($row = $query->fetch(PDO::FETCH_ASSOC)) {
    				$users[] = $row;
    			}
    		}
     
    		header('Content-Type: text/csv; charset=utf-8');
    		header('Content-Disposition: attachment; filename='.$csv_filename);
    		$output = fopen('php://output', 'w');
     
    		fputcsv($output, array('col1', 'col2', 'col3', 'col4', 'col5', 'col6');
     
    		if (count($users) > 0) {
    			foreach ($users as $data) {				
    				fputcsv($output, $data);
    			}
    		}
    		fclose($output);

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Ton fichier est probablement correctement construit, mais Excel ne le lit pas bien.

    fputcsv utilise par défaut la virgule (",") comme séparateur de colonnes. En général, Excel considère comme séparateur par défaut le point-virgule (";")
    Donc soit tu configures Excel pour qu'il comprenne les virgules en tant que séparateur, soit tu précises le séparateur dans ton code pour utiliser le point-virgule :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    fputcsv($output, $data, ';');
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Par défaut
    Bonjour

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $query->setFetchMode(PDO::FETCH_ASSOC);
    		$count = 30;
     
    		$users = array();
    		if ($count > 0) {
    			while ($row = $query->fetch(PDO::FETCH_ASSOC)) {
    				$users[] = $row;
    			}
    		}
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $users =  $query->fetchAll(PDO::FETCH_ASSOC);
    A+.

  4. #4
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2013
    Messages
    247
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2013
    Messages : 247
    Par défaut
    Merci à tous le problème est résolu.

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

Discussions similaires

  1. Exporter ListView vers CSV
    Par Zhamy dans le forum C#
    Réponses: 4
    Dernier message: 22/10/2011, 23h19
  2. IBPP Exportation Firebird vers CSV
    Par kase74 dans le forum C++
    Réponses: 1
    Dernier message: 29/09/2010, 16h54
  3. [MySQL] Exporter table vers csv via PhpMyAdmin
    Par mikael2235 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 09/06/2010, 20h47
  4. Export oracle vers csv
    Par MikeM dans le forum SQL
    Réponses: 5
    Dernier message: 11/02/2008, 14h11
  5. [SQL] exportation php vers csv
    Par yveslens dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 10/02/2007, 07h06

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