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, encodage et ;


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 530
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 530
    Par défaut CSV, encodage et ;
    Bonjour

    Je vais passer pour un benêt mais tant pis

    J'essaye de créer un csv à partir d'un tableau de chaînes:

    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
    34
    35
    36
     
    public sealed class ExportCSV
    {
     
        ExportCSV() { }
     
        public static void Export(string[][] datas, string fileName)
        {
            using (System.IO.StreamWriter sw = new System.IO.StreamWriter(@fileName, false, System.Text.UnicodeEncoding.Unicode))
            {
                foreach (string[] line in datas)
                {
                    sw.WriteLine(string.Join(";", line));
                }
     
            }
        }
    }
     
    ........
     
            private void button1_Click(object sender, EventArgs e)
            {
                string[][] lines = new string[3][];
                lines[0] = new string[5] {"A","Z€ù$â\"","E","R","T"};
                lines[1] = new string[4] {"Q","S","D",";;;G"};
                lines[2] = new string[5] {"L","C","","qsd.23","''J"};
                try
                {
                    ExportCSV.Export(lines, "c:\\test.csv");
                }
                catch (Exception exc)
                {
                    MessageBox.Show(exc.Message); 
                }            
            }
    Si je ne spécifie pas d'encoding, j'ai bien les colonnes quand j'ouvre le fichier dans Excel. Sinon, tout est dans la même colonne.

    Autre problème, sans encoding, j'ai bien les colonnes mais les valeurs du tableau qui comportent des ; crèent autant de colonnes supplémentaires . Est-il possible d'éviter ça ?

    Papy !

  2. #2
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 530
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 530
    Par défaut
    j'ai résolu le problème des ; en entourant les chaînes avec des "

    Mais l'encoding me pose toujours problème

  3. #3
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 530
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 530
    Par défaut
    ben voilà, désolé du dérangement
    J'ai trouvé tout seul:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
            public static void Export(string[][] datas, string fileName)
            {
                using (System.IO.StreamWriter sw = new System.IO.StreamWriter(@fileName, false, System.Text.UTF8Encoding.UTF8))
                {                
                    foreach (string[] line in datas)
                    {
                        sw.WriteLine(string.Join(";", line));
                    }
     
                }
            }

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

Discussions similaires

  1. [CSV] Problème d'encodage
    Par simoryl dans le forum Langage
    Réponses: 13
    Dernier message: 18/04/2012, 15h20
  2. [Encodage] import csv - encodage défaillant
    Par JerryOne3 dans le forum Langage
    Réponses: 6
    Dernier message: 06/01/2011, 17h47
  3. Réponses: 4
    Dernier message: 29/02/2008, 11h11
  4. [CSV] conflit d encodage
    Par philippe123 dans le forum Langage
    Réponses: 3
    Dernier message: 01/08/2006, 13h56
  5. [C#][CSV] souci d'encodage
    Par papouAlain dans le forum Windows Forms
    Réponses: 6
    Dernier message: 20/12/2005, 16h48

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