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 :

Importer des datas issues d'un fichier .csv dans une table Postgresql => erreur


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2017
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Décembre 2017
    Messages : 41
    Par défaut Importer des datas issues d'un fichier .csv dans une table Postgresql => erreur
    Bonjour,

    J'ai un tableau de données .CSV que je dois importer dans une table.

    Extrait du fichier csv :
    matricule;nom
    1;toto
    2;tata
    3;titi
    J'ai essayé d'utiliser psqlCopyFromArray mais j'ai en retour le message suivant :
    Fatal error: Uncaught PDOException: SQLSTATE[22P04]: Bad copy file format: 7 ERROR: literal newline found in data HINT: Use "\n" to represent newline.
    Voici ma méthode :

    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
    require_once 'connect_bd.php' // connection à la base de données
     
    $filename = $_FILES['userfile']['tmp_name'];  //recuperation du fichier envoyé en POST via le formulaire
     
    //Stockage des données dans un tableau et suppression des éventuelles lignes vides
    $data=[];
     
    $file=fopen($filename,"r");
     
    while (!feof($file)){
        $ligne= fgets($file,1024);
        array_push($data,$ligne);
    }
     
    print_r($data) //=> Array ( [0] => matricule;nom [1] => 1;TOTO [2] => 2;tata [3] => 3;titi ) 
     
     
    $fields=array_shift($data); // Retrieve & remove the field list
    $fields=str_replace(";",",",$fields);
    echo($fields); //=>matricule,nom
     
    print_r($data); //=> Array ( [0] => 1;TOTO [1] => 2;tata [2] => 3;titi ) 
     
    $delimiter = ";";
    $null_as=null;
     
    $result=$pdo->pgsqlCopyFromArray('geolis.r_import',$data,$delimiter,$null_as,$fields);
    Message d'erreur :

    Fatal error: Uncaught PDOException: SQLSTATE[22P04]: Bad copy file format: 7 ERROR: literal newline found in data HINT: Use "\n" to represent newline. CONTEXT: COPY r_import, line 3 in C:\ms4w\Apache\htdocs\cyneclic\fdcm\www\espace_prive\geolis\geolis_query2.php:45 Stack trace: #0 C:\ms4w\Apache\htdocs\cyneclic\fdcm\www\espace_prive\geolis\geolis_query2.php(45): PDO->pgsqlCopyFromArray('geolis.r_import', Array, ';', '', 'matricule,nom\r\n') #1 {main} thrown in C:\ms4w\Apache\htdocs\cyneclic\fdcm\www\espace_prive\geolis\geolis_query2.php on line 45
    Si quelqu'un peut me donner une piste pour résoudre ce problème, je suis preneur.

    Bon courage à tous

  2. #2
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 670
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 670
    Par défaut
    il y a peut être des sauts de ligne à la fin de chaque donnée. vous pouvez essayer de les retirer comme cela :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    $data = array_map(function ($e) {return trim($e);}, $data);

  3. #3
    Expert confirmé Avatar de CosmoKnacki
    Homme Profil pro
    Justicier interdimensionnel
    Inscrit en
    Mars 2009
    Messages
    2 986
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Justicier interdimensionnel

    Informations forums :
    Inscription : Mars 2009
    Messages : 2 986
    Par défaut
    Tu peux essayer de remplacer $ligne = fgets($file, 1024); par $ligne = stream_get_line($file, 1024, "\n");.

    stream_get_line fait exactement la même chose que fgets à la différence qu'il ne renvoie pas le délimiteur qu'on lui indique.

  4. #4
    Membre averti
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2017
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Décembre 2017
    Messages : 41
    Par défaut
    Bonjour,

    Je viens d'essayer ta méthode et j'ai toujours un message d'erreur :

    Fatal error: Uncaught PDOException: SQLSTATE[22P04]: Bad copy file format: 7 ERROR: literal newline found in data HINT: Use "\n" to represent newline. CONTEXT: COPY r_import_territoire, line 396 in C:\ms4w\Apache\htdocs\cyneclic\fdcm\www\espace_prive\geolis\geolis_query2.php:66 Stack trace: #0 C:\ms4w\Apache\htdocs\cyneclic\fdcm\www\espace_prive\geolis\geolis_query2.php(66): PDO->pgsqlCopyFromArray('geolis.r_import...', Array, ';', '', 'MATRICULE,CHASS...') #1 {main} thrown in C:\ms4w\Apache\htdocs\cyneclic\fdcm\www\espace_prive\geolis\geolis_query2.php on line 66
    Par contre j'ai essayé le code suivant et je n'ai plus d'erreur mais je ne sais pas vraiment pourquoi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    while (($line = fgetcsv($file)) !== FALSE) {
      //$line is an array of the csv elements
       $line = implode(',',$line);
       array_push($data,$line);
    }
    Si vous avez une explication je suis preneur.
    Merci pour votre aide

  5. #5
    Membre averti
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2017
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Décembre 2017
    Messages : 41
    Par défaut
    Re bonjour,

    Nouveau problème :

    Lors de mon export en csv depuis ma base métier, il y a une ligne vide à la fin :
    Nom : Sans titre.png
Affichages : 141
Taille : 9,4 Ko

    Si je supprime cette ligne manuellement tout fonctionne. Est ce qu'il y a un moyen d'ignorer cette ligne automatiquement ?

    Merci

  6. #6
    Expert confirmé Avatar de CosmoKnacki
    Homme Profil pro
    Justicier interdimensionnel
    Inscrit en
    Mars 2009
    Messages
    2 986
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Justicier interdimensionnel

    Informations forums :
    Inscription : Mars 2009
    Messages : 2 986
    Par défaut
    Si ça n'a pas marché avec stream_get_line c'est sans doute que la séquence de nouvelle ligne utilisé dans ton fichier n'est pas juste \n mais \r\n, il suffit juste de le préciser.

    Maintenant tu te compliques la vie: puisque tu passes toutes tes données d'un coup à ta base de données, pas la peine de te fatiguer avec fopen et une lecture ligne par ligne. Utilise directement la fonction file qui te mettra chaque ligne dans un tableau et qui en plus par le biais d'une option permet d'enlever automatiquement la séquence de nouvelle ligne et de filtrer les lignes vides (donc la dernière qui te pose problème).


    [EDIT]C'est bien array_shift et pas array_unshift[/EDIT]
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $data = file($filename, FILE_SKIP_EMPTY_LINES | FILE_IGNORE_NEW_LINES);
     
    $fields = strtr(array_shift($data), ';', ','); // doit-on vraiment changer le délimiteur ?
     
    $delimiter = ';';
    $null_as = null;
     
    $result = $pdo->pgsqlCopyFromArray('geolis.r_import', $data, $delimiter, $null_as, $fields);
    Ce type de code fonctionnera sous réserve qu'aucun de tes champs ne soit entre double quotes pour protéger un saut de ligne, sinon utilise fgetcsv.

Discussions similaires

  1. Importer un fichier csv dans une table mdb
    Par pobrouwers dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 02/12/2007, 14h17
  2. [WD9] Importer un fichier csv dans une table
    Par cactus666 dans le forum WinDev
    Réponses: 1
    Dernier message: 01/10/2007, 14h07
  3. Réponses: 3
    Dernier message: 15/05/2007, 09h28
  4. Importer un fichier CSV dans une table mySQL
    Par crazydiver_e2 dans le forum Requêtes
    Réponses: 4
    Dernier message: 16/01/2007, 10h47
  5. Impossible d'importer un fichier csv dans une table sous MySQL
    Par manue85 dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 20/04/2006, 12h06

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