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

Windows Forms Discussion :

Fichier CSV et Accent - Ascci Unicode


Sujet :

Windows Forms

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 13
    Par défaut Fichier CSV et Accent - Ascci Unicode
    (Re) Bonjour,

    Je suis en train de développer un module qui ouvre un fichier CSV, qui réarange les informations présentes et les réengistre dans un autre fichier CSV.

    Dans le fichier original, par de problème avec les é à ç ..... mais dans mon fichier final j'ai des caractères bizarres ....

    J'ai passé "System.Text.UnicodeEncoding.Unicode" en paramètre de mon fichier mais rien y fait ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Dim fichierexport As New StreamWriter("c:\" + TextBox2.Text + "260Export.csv", System.Text.UnicodeEncoding.Unicode)
    Merci

  2. #2
    Membre expérimenté Avatar de Faladin
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    333
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2007
    Messages : 333
    Par défaut
    Récupère le encoding du fichier ouvert et utilises le même pour le fichier que tu vas écrire

    Sinon, si tu restes local sur des PC français, utilise .Default au lieu de .Unicode, ça devrait fonctionner

  3. #3
    Membre expérimenté Avatar de Faladin
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    333
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2007
    Messages : 333
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.Text.Encoding.Default
    Pour être plus clair...

  4. #4
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 13
    Par défaut
    Voila mon source :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Dim fichierexport As New StreamWriter("c:\" + TextBox2.Text + "260Colorisfacade.csv")
     
    If My.Computer.FileSystem.FileExists(chemin) Then 'test si le fichier existe
    Dim fichier As New StreamReader(chemin)
    --> Avec ce code j'ai des problèmes avec les é à ç .....

    Avec la solution de Faladin, j'ai ce message d'erreur :


    Erreur 1 La résolution de surcharge a échoué, car aucun 'New' accessible ne peut être appelé avec ces arguments :
    'Public Sub New(path As String, append As Boolean)': Une valeur de type 'System.Text.Encoding' ne peut pas être convertie en 'Boolean'.
    'Public Sub New(stream As System.IO.Stream, encoding As System.Text.Encoding)': Une valeur de type 'String' ne peut pas être convertie en 'System.IO.Stream'.
    Une idée ?

  5. #5
    Rédacteur/Modérateur
    Avatar de Skalp
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 694
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 694
    Par défaut
    Erreur 1 La résolution de surcharge a échoué, car aucun 'New' accessible ne peut être appelé avec ces arguments :
    'Public Sub New(path As String, append As Boolean)': Une valeur de type 'System.Text.Encoding' ne peut pas être convertie en 'Boolean'.
    'Public Sub New(stream As System.IO.Stream, encoding As System.Text.Encoding)': Une valeur de type 'String' ne peut pas être convertie en 'System.IO.Stream'.
    Oui, une idée, oui. Le message me semble pourtant assez clair :
    Lorsque tu instancies ton StreamWriter, tu n'a pas de constructeur possible avec en paramètre 1 le chemin du fichier en string et en paramètre 2 l'encodage.
    Tu dois utiliser une autre surcharge de ce constructeur. Celle-ci devrait te convenir :
    StreamWriter(string path, bool append, Encoding encoding)
    (où "append" indique d'ajouter le texte dans le fichier ou pas)

    D'ailleurs, je ne pense pas que cette ligne de code que tu nous as montré compile :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim fichierexport As New StreamWriter("c:\" + TextBox2.Text + "260Export.csv", System.Text.UnicodeEncoding.Unicode)

  6. #6
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 13
    Par défaut
    Parfait !!

    Merci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Dim fichierexport As New StreamWriter("c:\" + TextBox2.Text + "260Colorisfacade.csv", False, System.Text.Encoding.Default)
     
            If My.Computer.FileSystem.FileExists(chemin) Then 'test si le fichier existe
                Dim fichier As New StreamReader(chemin, System.Text.Encoding.Default)

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 21/06/2011, 09h10
  2. problème d'accent sur le fichier csv
    Par olikhvar dans le forum Langage
    Réponses: 1
    Dernier message: 05/02/2011, 07h04
  3. Réponses: 5
    Dernier message: 11/07/2010, 14h07
  4. [SQL] Import de fichier csv et accents
    Par Mohican69 dans le forum Administration
    Réponses: 2
    Dernier message: 15/05/2010, 18h05
  5. Génération fichier csv problème accent
    Par marion782 dans le forum ASP.NET
    Réponses: 2
    Dernier message: 11/08/2009, 09h16

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