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

C# Discussion :

CSV : problème d'encodage


Sujet :

C#

  1. #1
    Membre éclairé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2006
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juin 2006
    Messages : 645
    Points : 709
    Points
    709
    Par défaut CSV : problème d'encodage
    Bonjour,

    je cherche à générer un fichier CSV. J'utilise ce code pour la construction :
    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
    private void BuildCsv(ref MemoryStream memStream)
      {
        StreamWriter sw = new StreamWriter(memStream,System.Text.Encoding.UTF8);
     
        sw.WriteLine("Un texte de résumé"); 
     
        // En-tête
        sw.WriteLine(String.Format("\"{0}\" ; \"{1}\" ; \"{2}\" ; \"{3}\" ; \"{4}\" ; \"{5}\" ; \"{6}\"",
          col1,
          col2,
          col3,
          col4,
          col5,
          col6,
          col7));
     
        // Donnees
        foreach (IStnDes res in maliste)
        {
          sw.WriteLine(String.Format("\"{0}\" ; \"{1}\" ; \"{2}\" ; \"{3}\" ; \"{4}\" ; \"{5}\" ; \"{6}\"",
          res.ch1, 
          res.ch2, 
          res.ch3, 
          res.ch4, 
          res.ch5, 
          res.ch6, 
          res.ch7));
        }
     
        // Nettoyage du streamwritter
        sw.Flush();
        sw.Close();
      }
    L'envoi à l'utilisateur se fait ainsi :
    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
    byte[] byteArray = memStream.ToArray();
     
                //Nettoyage du MemoryStream
                memStream.Flush();
                memStream.Close();
                // Nettoyage du contenu de sortie
                Context.Response.Clear();
                // Header HTTP qui donne le fichier par défaut à aller chercher
                Context.Response.AddHeader("Content-Disposition", "attachment; filename=" + strCsvFileName + ".csv");
                // Header HTTP qui contient la taille de fichier
                Context.Response.AddHeader("Content-Length", byteArray.Length.ToString());
                // MIME type
                Context.Response.ContentType = "application/octet-stream";
                // Ecriture des données binaire sur le flux de sortie
                Context.Response.BinaryWrite(byteArray);
    Avec ceci, lorsque je suis en UTF8, les accents passent bien mais Excel ne "voit" pas les colonnes (tout est importé dans la même colonne).
    Si j'encode en ASCII, les accents sont affichés comme des points d'interrogation, mais les colonnes sont bien "détectées".

    Je ne comprends pas bien pourquoi... donc si vous aviez une piste !

    Merci d'avance !

    Alban

  2. #2
    Membre éclairé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2006
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juin 2006
    Messages : 645
    Points : 709
    Points
    709
    Par défaut
    Finalement, c'était tout bête :il ne fallait ni utiliser UTF8, ni ASCII

    J'ai remplacé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StreamWriter sw = new StreamWriter(memStream,System.Text.Encoding.UTF8);
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StreamWriter sw = new StreamWriter(memStream,System.Text.Encoding.Default);
    et ça fonctionne.

    Avec le code précédent, les guillemets autour de champs restaient cependant, mais en supprimant les espaces de part et d'autre des points-virgule, tout fonctionne.

    Désolé pour le bruit !

  3. #3
    Membre éclairé
    Inscrit en
    Octobre 2006
    Messages
    587
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations forums :
    Inscription : Octobre 2006
    Messages : 587
    Points : 706
    Points
    706
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    sw.Flush();
    sw.Close();
    L'envoi à l'utilisateur se fait ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    memStream.Flush();
    memStream.Close();
    Petite remarque: ton flush ne sert à rien vu que la méthode Close appelle la méthode Flush automatiquement...

  4. #4
    Membre éclairé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2006
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juin 2006
    Messages : 645
    Points : 709
    Points
    709
    Par défaut
    Je suis d'accord... mais j'aime bien prendre mes précautions
    Je n'ai pas toujours confiance dans ce genre de choses (référence à un OleDbCommand qui ne libère pas la liste de paramètres quand on lance Dispose par exemple).
    Si ça ne sert à rien... ça ne sert à rien, mais le jour où ça m'évite des bugs que je ne comprends pas, je suis content

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

Discussions similaires

  1. Problème d'encodage dans l'importation d'un .csv
    Par Sayanel01 dans le forum Général VBA
    Réponses: 2
    Dernier message: 30/04/2015, 22h17
  2. [CSV] Problème d'encodage
    Par simoryl dans le forum Langage
    Réponses: 13
    Dernier message: 18/04/2012, 15h20
  3. Problème d'encodage de fichier (.csv-->.sql, .sql-->.csv)
    Par croustibapt dans le forum Entrée/Sortie
    Réponses: 5
    Dernier message: 09/07/2009, 10h17
  4. Problème d'encodage sur MySql 4.1
    Par Blanchet dans le forum Outils
    Réponses: 1
    Dernier message: 04/12/2005, 04h53
  5. [XML::PARSER] Problème d'encodage
    Par frangin2003 dans le forum Modules
    Réponses: 13
    Dernier message: 05/09/2005, 14h59

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