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

ASP.NET Discussion :

Génération fichier csv problème accent


Sujet :

ASP.NET

  1. #1
    Membre confirmé
    Inscrit en
    Décembre 2004
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 113
    Par défaut Génération fichier csv problème accent
    Bonjour,

    Je souhaite, en cliquant sur un bouton, générer un fichier csv, avec le contenu d'un datatable, que l'utilisateur pourra ouvrir ou enregistrer. J'utilise la fonction suivante qui marche sauf pour les lettres accentuées :-( J'ai essayé différents charset mais rien ne fait... j'ai toujours é pour é par exemple...
    Si vous avez des idées, je suis preneuse car je commence sérieusement à désepérer!
    Merci d'avance!

    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 static void ExportCSV(DataTable pDataTable) 
    		{
    			HttpContext.Current.Response.ClearHeaders();
    			HttpContext.Current.Response.Clear();
    			HttpContext.Current.Response.Buffer = true;
    			HttpContext.Current.Response.ContentType = "text/csv";
    			HttpContext.Current.Response.Charset = "ISO-8859-1";
    			HttpContext.Current.Response.AddHeader("content-disposition", "attachment; filename=exportCsv.csv");
     
    			StringBuilder sb = new StringBuilder();
    			//S'il y a des données
    			if(pDataTable.Columns.Count != 0)
    			{    				
    				//Ligne d'entêtes 
    				foreach(DataColumn column in pDataTable.Columns)
    				{
    					sb.Append(column.ColumnName + ';');
    				}
    				//Retour à la ligne
    				sb.Append("\r\n");
    				//boucle sur les données
    				foreach(DataRow row in pDataTable.Rows)
    				{	
    					//parcours des colonnes
    					foreach(DataColumn column in pDataTable.Columns)
    					{
    						sb.Append(row[column].ToString().Replace(Environment.NewLine,"[retour à la ligne]").Replace(";",",")+';');
    					}
    					//Retour à la ligne
    					sb.Append("\r\n");
    				}
    			}
     
    			HttpContext.Current.Response.Write(sb);
    			HttpContext.Current.Response.End();
    		}

  2. #2
    Membre Expert
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Par défaut
    Ce n'est pas une question de charset mais d'encoding.

    Pour des raisons de globalisation, ASP.NET retourne en général de l'UTF-8. Excel lui, ne lit correctement que de l'ANSI. A mon avis, si tu ajoutes un HttpContext.Current.Response.ContentEncoding = Encoding.Default ça devrait fonctionner (j'ai pas testé).

  3. #3
    Membre confirmé
    Inscrit en
    Décembre 2004
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 113
    Par défaut
    Merci ça marche!

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

Discussions similaires

  1. [SQL] Import de fichier csv et accents
    Par Mohican69 dans le forum Administration
    Réponses: 2
    Dernier message: 15/05/2010, 18h05
  2. Réponses: 3
    Dernier message: 16/01/2009, 16h27
  3. Fichier CSV et Accent - Ascci Unicode
    Par nicleco dans le forum Windows Forms
    Réponses: 5
    Dernier message: 19/08/2008, 10h52
  4. import de fichier CSV : problème de caractères accentués
    Par mouaa dans le forum Administration
    Réponses: 2
    Dernier message: 08/08/2007, 07h45
  5. Télécharger un fichier CSV (problème de version)
    Par SPOUTNIK007 dans le forum ASP
    Réponses: 1
    Dernier message: 20/10/2006, 12h16

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