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 :

Gestion des points-virgule dans un CSV


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Femme Profil pro
    Etudiante en BTS Informatique de Gestion
    Inscrit en
    Janvier 2010
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiante en BTS Informatique de Gestion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 7
    Par défaut Gestion des points-virgule dans un CSV
    bonjour,

    ma ligne dans mon csv doit être comme ceci :
    179A07EBEA83E46181CCF474BAE1E4E22FCE8E659D1F7FBAD0AFA3AD942CA6EA;available;1400163513;2;tre;tre;tre

    et lorsque l'utilisateur souhaite modifier un champ (entre 2 à l'aide d'=un formulaire, il n'y a pas de problème, sauf s'il insert un ;. Je souhaite remplacer ce ';' par ',' mais comme vous le voyez en gras, dans ce cas ma ligne devient :
    "179A07EBEA83E46181CCF474BAE1E4E22FCE8E659D1F7FBAD0AFA3AD942CA6EA;available;1400163513;2;tre;tr,e;tre"

    Mon code est le suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $carToReplace = array(';', '"');
    $donnees[4] = str_replace($carToReplace, ',', $donnees[4]);
    $donnees[5] = str_replace($carToReplace, ',', $donnees[5]);
    $donnees[6] = str_replace($carToReplace, ',', $donnees[6]);
    Seuls les 3 derniers champs posent problème, les autres étant volontairement en readonly dans le formulaire de modification.

    Je fais ensuite mon insertion dans le fichier csv :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $line = $donnees[0].';'.$donnees[1].';'.$donnees[2].';'.$donnees[3].';'.$donnees[4].';'.$donnees[5].';'.$donnees[6];
    fputcsv($fichier,explode(' ; ',$line));
    Si vous avez la solution, je vous en serais reconnaissante car cela fait un bon moment que je cherche la solution, en vain.
    J'ai également testé en ajoutant htmlentities mais cela ne change rien.

    Merci de votre aide

  2. #2
    Membre Expert

    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Par défaut
    Entoure l'ensemble de tes valeurs de guillemets doubles.

  3. #3
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $data = array($donnees[0],$donnees[1],$donnees[2],$donnees[3],$donnees[4],$donnees[5],$donnees[6]);
    fputcsv($fichier,$data, ';');
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

Discussions similaires

  1. Supprimer les espaces compris entre deux points virgules dans un fichier csv
    Par moctarim dans le forum Shell et commandes POSIX
    Réponses: 2
    Dernier message: 04/01/2013, 17h03
  2. Gestion des points vides dans un graphique 3D
    Par guidav dans le forum IHM
    Réponses: 0
    Dernier message: 29/06/2012, 11h20
  3. [XL-2003] CSV : Des cases vides qui génèrent des points virgules
    Par orke22 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 15/09/2011, 15h08
  4. Réponses: 6
    Dernier message: 03/05/2007, 13h42
  5. Gestion des message windows dans les threads
    Par billyboy dans le forum Windows
    Réponses: 5
    Dernier message: 06/10/2003, 17h25

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