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 :

Créer un fichier csv pour l'envoyer sur un serveur FTP [Débutant]


Sujet :

C#

  1. #1
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut Créer un fichier csv pour l'envoyer sur un serveur FTP
    Bonjour,

    je cherche un exemple de code pour m'aider à créer un fichier de type CSV afin de l'envoyer sur un serveur FTP.
    je cherche une solution qui ne nécessite pas de créer le fichier de façon temporaire.

    le serveur FTP est un serveur sécurisé (SFTP)

    merci par avance de votre aide.

  2. #2
    Expert confirmé

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Septembre 2006
    Messages
    3 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 580
    Points : 5 194
    Points
    5 194
    Par défaut
    bonjour

    Création fichier csv ==> Une simple écriture dans un fichier text que tu nommes .csv en séparant chaque champs par un ";"

    (la première ligne peut être le nom des colonnes (séparées par ; également)...

    Pour le FTP, je te conseille cette librairie, simple et rapide d'utilisation :

    dotnetftplib

  3. #3
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut
    j'ai commencé par faire ce code

    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
    37
    38
    39
    40
    41
     
            /// <summary>
            /// 
            /// </summary>
            private byte[] createCsvFile()
            {
                UnicodeEncoding uniEncoding = new UnicodeEncoding();
                byte[] byteArray;
                int count;
     
                MemoryStream memoryStrm = new MemoryStream();
     
                string headerString = createHeaderFile();
                memoryStrm.Write(uniEncoding.GetBytes(headerString), 0, headerString.Length);
     
     
                // Write the stream properties to the console.
                CurrentContext.Message.Display(
                    "Capacity = {0}, Length = {1}, Position = {2}\n",
                    memoryStrm.Capacity.ToString(),
                    memoryStrm.Length.ToString(),
                    memoryStrm.Position.ToString());
     
                // Set the position to the beginning of the stream.
                memoryStrm.Seek(0, SeekOrigin.Begin);
     
                // Read the first 20 bytes from the stream.
                byteArray = new byte[memoryStrm.Length];
                count = 0;
     
                // Read the remaining bytes, byte by byte.
                while (count < memoryStrm.Length)
                {
                    byteArray[count++] =
                        Convert.ToByte(memoryStrm.ReadByte());
                }
     
     
                return byteArray;
     
            }
    en m'apuyant sur la msdn https://msdn.microsoft.com/fr-fr/lib...v=vs.110).aspx

    pour le moment mon fichier à une seule cvaleur "Titre" j'obtient bien un fichier au bout mais je n'ai plus que "Tit" , j'avoue ne pas trop savoir pourquoi

  4. #4
    Expert confirmé

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Septembre 2006
    Messages
    3 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 580
    Points : 5 194
    Points
    5 194
    Par défaut
    salut

    utilise un streamWriter, ça sera aussi simple...

  5. #5
    Expert confirmé

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Septembre 2006
    Messages
    3 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 580
    Points : 5 194
    Points
    5 194
    Par défaut
    du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    string path = @"c:\monchemin\toto.csv";
                StreamWriter write = new StreamWriter(path);
                foreach (var d in myData)
                {
                    write.WriteLine(d);
                }
                write.Close();
    ou myData serait la une liste des lignes à écrires (par exemple, une liste d'objet)...
    et dans ton "ToString()" de ta classe d, tu auras une surcharge du toString() pour formatter correctement une ligne (par exemple)...

    Et avant le foreach, tu peux faire un truc du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    write.WriteLine("Header1;Header2; etc...");
    ou header1,xxx sont les noms de tes colonnes...

  6. #6
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut
    j'ai une contrainte , je ne peux générer le fichier localement avant envoi sur le serveur FTP.
    je m'oriente vers l'option memorystream

    j'ai revu mon code , essentiellement la section stream to byte

    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
     
            /// <summary>
            /// 
            /// </summary>
            private byte[] createCsvFile()
            {
     
                byte[] byteArray;
     
                UnicodeEncoding uniEncoding = new UnicodeEncoding();
     
                // Create the data to write to the stream.
                byte[] firstString = uniEncoding.GetBytes(createHeaderFile());
     
                using (MemoryStream memStream = new MemoryStream())
                {
                    // Write the first string to the stream.
                    memStream.Write(firstString, 0, firstString.Length);
     
     
                    byteArray = ((MemoryStream)memStream).ToArray(); 
     
     
                }
     
                return byteArray;
     
            }
    pour le moment mon fichier est très simple il y a un mot. cette fois j'ai le mot complet. je me pose la question de la taille possible du fichier ? je pense être à moins de 5000 lignes avec une 50enes de colonnes.

    la section FTP n'est pas sécurisé je reviendrai dessus.

  7. #7
    Expert confirmé

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Septembre 2006
    Messages
    3 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 580
    Points : 5 194
    Points
    5 194
    Par défaut
    salut

    par rapport à la mémoire, ça devrait passer sans soucis...

    Après, ton streamWriter, tu peux l'utiliser avec un memorystream...

  8. #8
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut
    je suis donc arrivé à ce code
    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
    37
    38
    39
    40
    41
    42
    43
    44
    45
     
            /// <summary>
            /// Creation du fichier csv
            /// </summary>
            private byte[] createCsvFile(List<ObField> listOfFileField, List<ObResource> lstOfResources)
            {
                byte[] byteArray;
     
                UnicodeEncoding uniEncoding = new UnicodeEncoding();
     
                // File Header
                string headerLine = createHeaderFile(listOfFileField);
     
                using (MemoryStream memStream = new MemoryStream())
                {
                    using (var csvWriter = new StreamWriter(memStream, Encoding.UTF8))
                    {
                        // Write the header of file
                        csvWriter.WriteLine(headerLine);
     
                        //Write the file
                        foreach (ObResource obResource in lstOfResources)
                        {
                            string resource_title, resource_name, resource_maidenName, resource_firstName;
     
                            resource_title = obResource.resource_title;
                            resource_name = obResource.resource_name;
                            resource_maidenName = obResource.resource_maidenName;
                            resource_firstName = obResource.resource_firstName;
     
                            string ligne = resource_title + ";" + resource_name + ";" + resource_maidenName + ";" + resource_firstName + ";";
                            csvWriter.WriteLine(ligne);
                        }
     
                        csvWriter.Flush();
                    }
     
                    byteArray = ((MemoryStream)memStream).ToArray(); 
                }
     
     
     
                return byteArray;
     
            }
    j'utilise effectivement le streamWriter avec un memorystream

  9. #9
    Membre actif
    Homme Profil pro
    Developpeur
    Inscrit en
    Février 2013
    Messages
    180
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Developpeur

    Informations forums :
    Inscription : Février 2013
    Messages : 180
    Points : 271
    Points
    271
    Par défaut
    Bonjour,

    j'arrive une fois la bataille terminer, mais vaut mieux tard que jamais.
    Si cela peut aider les prochains.


    Création CSV :
    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
    37
    38
     
           //utilisation
           Serialisation.Serialiseur.getSerializer(pathfile, _listData, parametrage);
     
     
            internal void Serialiser(string pathfile, ExportCegidParam.BO.DataExport donnees, ExportCegidParam.BO.Parametrage parametrage)
            {
                try
                {
                    using (System.IO.StreamWriter sw = new System.IO.StreamWriter(pathfile, false, parametrage.Encodage))
                    {
                        string strTmp = "";
                        if (parametrage.Entete)
                        {
                            foreach (string entete in donnees.Entetes)
                            {
                                strTmp += entete + parametrage.Separateur;
                            }
                            sw.WriteLine(strTmp.Substring(0, strTmp.Length - 1));
                        }
                        foreach (ExportCegidParam.BO.Ligne ligne in donnees.Lignes)
                        {
                            strTmp = "";
                            foreach (ExportCegidParam.BO.Element element in ligne.Elements)
                            {
                                strTmp += element.Value + parametrage.Separateur;
                            }
                            sw.WriteLine(strTmp.Substring(0, strTmp.Length - 1));
                        }
                        sw.Flush();
                        sw.Close();
                    }
                }
                catch (Exception ex)
                {
                    throw new ApplicationException("Une erreur est survenue lors de la génération du fichier CSV ," + ex.Message);
                }
            }
    Envoi FTP :
    utilisation d'un utilitaire (WinSCP) pour nous aider à gérer nos connexion.
    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
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
     
            private void SendWindSCP(Parametrage parametrage)
            {
                try
                {
                    //création du fichier text de script
                    string pathFileScript = System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "EXPORT_FTP.txt");
                    if (System.IO.File.Exists(pathFileScript)) { System.IO.File.Delete(pathFileScript); }
                    using (System.IO.StreamWriter sw = new System.IO.StreamWriter(pathFileScript, false, Encoding.ASCII))
                    {
                        sw.WriteLine(@"open """ + parametrage.SessionWinSCP + "");
                        sw.WriteLine("option batch on");
                        sw.WriteLine("option confirm off");
                        sw.WriteLine("cd /");
                        sw.WriteLine(@"lcd """ + parametrage.PathDirDest + "");
                        sw.WriteLine("put " + parametrage.NameFile);
                        sw.WriteLine("exit");
                        sw.Flush();
                        sw.Close();
                    }
                    //transfere via WINSCP
                    Outils.Process.Execute(parametrage.PathWinSCP, @"/console /script=""" + pathFileScript + "");
                    //SUppression du fichier de script
                    if (System.IO.File.Exists(pathFileScript)) { System.IO.File.Delete(pathFileScript); }
                }
                catch (Exception ex)
                {
                    throw new ApplicationException("Erreur lors de l'envoi par FTP, fichier :" + parametrage.PathWinSCP + 
                        ", session : " + parametrage.SessionWinSCP + 
                        ", Erreur : " + ex.Message);
                }
            }
     
     
            public static void Execute(string fileName, string argument)
            {
                using (System.Diagnostics.Process proc = new System.Diagnostics.Process
                {
                    StartInfo = new System.Diagnostics.ProcessStartInfo
                    {
                        FileName = @fileName,
                        Arguments = @argument,
                        UseShellExecute = true,
                        RedirectStandardOutput = false,
                        CreateNoWindow = true,
                        WindowStyle = System.Diagnostics.ProcessWindowStyle.Normal
                    }
                })
                {
                    proc.Start();
                    proc.WaitForExit();
                    proc.Close();
                    proc.Dispose();
                }
            }

    Sources :
    je n'ai pas mis tous le projet, il y a des données que vous n'avez pas à avoir ^^ mais se code source ce comprend par lui même.
    Fichiers attachés Fichiers attachés

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

Discussions similaires

  1. [XL-2013] Créer un fichier CSV pour importation contacts dans Outlook
    Par lety 't be dans le forum Excel
    Réponses: 4
    Dernier message: 23/12/2019, 18h49
  2. Réponses: 2
    Dernier message: 13/10/2011, 23h00
  3. Réponses: 0
    Dernier message: 19/04/2011, 14h34
  4. Réponses: 3
    Dernier message: 12/08/2009, 10h11
  5. Réponses: 3
    Dernier message: 19/05/2007, 17h19

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