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 :

Lire les données d'un fichier csv, et les ajouter dans une Bdd SQL.


Sujet :

C#

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 47
    Points : 34
    Points
    34
    Par défaut Lire les données d'un fichier csv, et les ajouter dans une Bdd SQL.
    Bonjour à tous,

    Je suis étudiant en informatique, et j'ai commencé le C# il y 4 mois...

    Je suis actuellement en train de réaliser un projet dans le cadre du cours de Technologie Internet (.NET). Ce Projet consiste à réaliser une application Online de gestion de club (MVC 3 "razor" avec Bdd SQL)...Voilà un peu pour le contexte

    -Je suis en train d'utiliser l'Entity Framework 4.0 "Code First", c'est à dire que je code chacune de mes tables en classes pour ensuite créer une Bdd...

    -Une fois toutes ces classes implémentées, j'ai créé "le contexte de la Bdd", c'est là où je décide des entités à inclure dans le "DataModel" entre autre...

    ==>Puis, j'utilise une classe "Initializer" qui est censé remplir la bdd avec des données par défaut, C'est ICI que je cale En fait je dois remplir la Bdd avec des données inclues dans un fichier "csv", ce fichier contient 8 colonnes que voici:

    Num;Nom;Prénom;Adresse;Code Postal;Localité;Gsm;Date de naissance

    Mais je n'ai aucune idée de comment procéder voici ma classe Initializer :



    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
    namespace TennisOnline.DAL
    {
        public class TennisOnlineInitializer : DropCreateDatabaseIfModelChanges<TennisOnlineContext>
        {
            protected override void Seed(TennisOnlineContext context)
            {
     
     
                var customers = new List<Customer>
                {
     
                 //Voilà comment je ferais si je devais ajouter ces données à la main:( Il y a 412 clients en tout :mouarf:
     
                   /* new Customer { Pin=null ,Name="Adam",FirstName="Stéphanie",Mail=null, Address="Rue de Val-Dieu, 33",City="Aubel",PostalCode=4880, PhoneNumber="0475/963054",AffiliationNumber=4064891},*/
     
    //C'est donc ici que je dois remplir ma liste de clients répertoriés dans le fichier "Customer.csv"
     
                };   
    //C'est ici que j'ajoute tous les clients à la bdd
                customers.ForEach(s => context.Customers.Add(s));
                context.SaveChanges();
            }  
        }
    }


    Pouvez-vous m'aider SVP ? Je vous en serais reconnaissant

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par Fra212 Voir le message
    En fait je dois remplir la Bdd avec des données inclues dans un fichier "csv", ce fichier contient 8 colonnes que voici:

    Num;Nom;Prénom;Adresse;Code Postal;Localité;Gsm;Date de naissance

    Mais je n'ai aucune idée de comment procéder voici ma classe Initializer :
    C'est pourtant beaucoup plus simple que ce que le reste de ce que tu as fait jusqu'ici... Il suffit de lire le fichier ligne par ligne avec un StreamReader ou File.ReadLines, et de "splitter" chaque ligne selon le caractère de séparation. Tu récupères un tableau de chaines, et tu remplis tes objets avec...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    foreach(string line in File.ReadLines(csvFileName))
    {
        string[] parts = line.Split(';');
        var cust = new Customer();
        cust.Name = parts[1];
        cust.FirstName = parts[2];
        // etc...
     
        context.Customers.Add(cust);
    }

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 47
    Points : 34
    Points
    34
    Par défaut
    Merci beaucoup de la réponse Tomlev, ça fonctionne !

    Désolé de la réponse tardive !

    Bonne journée!

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 11/12/2014, 10h38
  2. [XL-2007] Récuperer les données d'un fichier et traiter les données
    Par kekefff dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 05/05/2014, 20h29
  3. Lire un fichier CSV dont les données contiennent des points
    Par black cat747 dans le forum MATLAB
    Réponses: 16
    Dernier message: 23/02/2011, 11h51
  4. [MySQL] Importer les données d'un fichier CSV dans une base de données
    Par joueur dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 12/11/2008, 11h59
  5. Réponses: 4
    Dernier message: 15/08/2006, 17h40

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