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 donnée d'une table mysql vers .csv (avec la fonction fputcsv)


Sujet :

Langage PHP

  1. #1
    Candidat au Club
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Octobre 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2017
    Messages : 4
    Points : 3
    Points
    3
    Par défaut Export donnée d'une table mysql vers .csv (avec la fonction fputcsv)
    Bonjour à tous,

    Tout d'abord je tiens a signaler que je suis complétement newbie dans le developpement pour éviter qu'on m'envoie des tomates.
    Voila ma problématique :
    Je souhaite récupérer les données d'une table mysql dans un .csv ,avec comme critere :
    delimiter : ,
    enclosuer : "
    escape_char : le retour à la ligne \n

    J'arrive bien a accéder à ma table et a son contenu, mais mon fichier .csv me donne un résultat comme ci-dessous :
    1,14,NULL,,1,2,"BORDEAUX",AGT,92600,2017
    2,14,NULL,,1,2,"PARIS",ATS,92400,2017

    Je souhaiterais que tous mes champs soient encadrés par des " :

    "1","14","","1","BORDEAUX","AGT","92600","2017"
    "2","14","","1","PARIS","ATS","92400","2017"



    voici mon pauvre code (on se moque pas) :

    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
     
    <?php
    date_default_timezone_set('Europe/Paris');
     
    $mysqli = new mysqli("localhost", "root", "", "test");
     
     
    /* Vérification de la connexion */
    if (mysqli_connect_errno()) {
        printf("Échec de la connexion : %s\n", $mysqli->connect_error);
        exit();
    }
    /*ouverture fichier*/
    $handle = fopen('test_'.date('Ymd_His').'.csv', 'w');
     
     
    $reponse=$mysqli->query('SELECT ID,NUM_SS,CODE_SS,MODE,VILLE,CP,ANNEE FROM TEST') or die (print_r($mysqli->errorInfo()));
     
     
    while($donnees = $reponse->fetch_assoc()) {
        fputcsv($handle, $donnees,',','"',");
    }
    $reponse->free();
    fclose($handle);
    
    $mysqli->close();
    ?>

    Si une âme charitable peut se pencher sur cette problèmatique plutot basique je pense je lui serais redevable =
    Merci de votre attention

  2. #2
    Candidat au Club
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Octobre 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2017
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    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
    <?php
    date_default_timezone_set('Europe/Paris');
    $mysqli = new mysqli("localhost", "root", "", "test");
     
     
    /* Vérification de la connexion */
    if (mysqli_connect_errno()) {
    printf("Échec de la connexion : %s\n", $mysqli->connect_error);
    exit();
    }
    /*ouverture fichier*/
    $handle = fopen('test_'.date('Ymd_His').'.csv', 'w');
     
     
    $reponse=$mysqli->query('SELECT ID,NUM_SS,CODE_SS,MODE,VILLE,CP,ANNEE FROM TEST') or die (print_r($mysqli->errorInfo()));
     
     
     
    while($donnees = $reponse->fetch_assoc()) {
    fputcsv($handle, $donnees,',','"',");
    }
    $reponse->free();
    fclose($handle);
    
    $mysqli->close();

  3. #3
    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 : 39
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Ton problème vient du fait que fputcsv ne met des délimiteurs de champs que si la donnée lui parait poser problème. Donc il va encadrer "toto fait du vélo" (à cause des espaces) ou 1,3 à cause de la virgule (qui est aussi le séparateur) mais pas 42. Si tu veux forcer les délimiteurs, il va falloir le faire à la main...
    La question, c'est as-tu réellement besoin de ces délimiteurs supplémentaires ?

  4. #4
    Candidat au Club
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Octobre 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2017
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Tout d'abord, merci pour ta réponse,

    Oui, en gros je dois avoir un resultat avec tout les champs encadrés par des ""
    par contre je vois pas du tout par ou commencer.
    Quel est le moyen le plus simple de remplacer tous mes champs dans mon fichier csv avec des guilemets (fonction? méthode...)

    Merci d'avance

  5. #5
    Candidat au Club
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Octobre 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2017
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Merci google c'est bon pour moi
    Merci encore Celira

    Pour ceux qui veulent (ca fonctionne tres bien chez moi) tous mes champs sont entre "" )

    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
    ini_set('error_reporting', E_ALL);
    ini_set('display_errors', 1);
     
    function fputcsv2($fp, $fields, $delimiter = ',', $enclosure = '"', $mysql_null = false) {
        $delimiter_esc = preg_quote($delimiter, '/');
        $enclosure_esc = preg_quote($enclosure, '/');
     
        $output = array();
        foreach ($fields as $field) {
            if ($field === null && $mysql_null) {
                $output[] = 'NULL';
                continue;
            }
     
            // original
            // $output[] = preg_match("/(?:${delimiter_esc}|${enclosure_esc}|\s)/", $field) ? (
            //     $enclosure . str_replace($enclosure, $enclosure . $enclosure, $field) . $enclosure
            // ) : $field;
     
            $output[] = preg_match("/(?:${delimiter_esc}|${enclosure_esc}|\s)/", $field) ? (
                $enclosure . str_replace($enclosure, $enclosure . $enclosure, $field) . $enclosure
            ) : "\"{$field}\"";
        }
     
        fwrite($fp, join($delimiter, $output) . "\n");
    }

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

Discussions similaires

  1. [MySQL] Exporter une table Mysql vers CSV en utilisant PHP
    Par skins dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 09/06/2010, 20h33
  2. Réponses: 2
    Dernier message: 13/10/2009, 12h55
  3. [Excel] Exporter une table MySQL vers un fichier .XLS sous linux
    Par Jlecp dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 20/03/2008, 19h59
  4. Exporter une table MySQL vers un fichier CSV
    Par sam01 dans le forum Outils
    Réponses: 2
    Dernier message: 07/08/2007, 16h44
  5. Réponses: 1
    Dernier message: 21/07/2006, 11h54

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