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 :

Récupérer le nombre de champs d'un élément d'un tableau


Sujet :

C#

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2018
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2018
    Messages : 34
    Points : 24
    Points
    24
    Par défaut Récupérer le nombre de champs d'un élément d'un tableau
    Bonjour,

    Désolé si l'intitulé n'est pas clair mais un exemple expliquera mieux que moi :

    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
    var Client = new[]
                {
                    new {
                        Designation="Client 1",
                        Profil="profil 1",
                        Adresse="Adresse 1",
                        Pays="France"
                    },
                    new {
                        Designation="Client 2",
                        Profil="profil 2",
                        Adresse="Adresse 2",
                        Pays="France"
                    }
                };
    Je sais que Client.length va me donner le nombre de clients dans mon tableau mais j'aimerais récupérer le nombre champs par client (dans cet exemple 4) et le nom des champs ("Designation", "Profil", "Adresse", "Pays").
    C'est possible?

  2. #2
    Membre chevronné
    Homme Profil pro
    edi
    Inscrit en
    Juin 2007
    Messages
    905
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : edi

    Informations forums :
    Inscription : Juin 2007
    Messages : 905
    Points : 1 923
    Points
    1 923
    Par défaut
    Tu peux récupérer la liste des propriétés de ton type par la reflection :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    typeof(Client).GetProperties(BindingFlags.Instance | BindingFlags.Public).Select(p => p.Name).OrderBy(n => n).ToArray()

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2018
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2018
    Messages : 34
    Points : 24
    Points
    24
    Par défaut
    Merci pour ta réponse.
    J'ai cette erreur là sur le .typeof(Client) :
    CS0118: 'Client' est un variable mais est utilisé comme un type

  4. #4
    Membre chevronné
    Homme Profil pro
    edi
    Inscrit en
    Juin 2007
    Messages
    905
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : edi

    Informations forums :
    Inscription : Juin 2007
    Messages : 905
    Points : 1 923
    Points
    1 923
    Par défaut
    Si tu as une variable il te faut faire maVar.GetType().GetProperties.... Si tu as un tableau il te faut parcourir tous les éléments de ce tableau avec ce code. Par contre, pourquoi est-ce-que tu crées à la volée un ensemble d'objets avec un type anonyme ? Si tous tes objets ont les même propriétés tu devais avoir une classe associée. Par ailleurs ta variable Client devrait s'appeler clients ('c' minuscule parce-que c'est une variable, pluriels parce-que c'est une collection d'objets).

  5. #5
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2018
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2018
    Messages : 34
    Points : 24
    Points
    24
    Par défaut
    Si tu as un tableau il te faut parcourir tous les éléments de ce tableau avec ce code
    Merci, ça marche nickel

    Par contre, pourquoi est-ce-que tu crées à la volée un ensemble d'objets avec un type anonyme ?
    C'est juste des données test pour un projet que j'ai créer rapidement pour tester l'export vers excel avec EPPLUS. C'est un exemple "bateau" pour garder une discrétion sur le code de l'application de l'entreprise où je travaille. J'aurai adapté le code après.

    Par ailleurs ta variable Client devrait s'appeler clients ('c' minuscule parce-que c'est une variable, pluriels parce-que c'est une collection d'objets)
    On me le dis souvent ça, j'essaye de m'améliorer là-dessus.

  6. #6
    Membre chevronné
    Homme Profil pro
    edi
    Inscrit en
    Juin 2007
    Messages
    905
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : edi

    Informations forums :
    Inscription : Juin 2007
    Messages : 905
    Points : 1 923
    Points
    1 923
    Par défaut
    Citation Envoyé par Kikibolderiz Voir le message
    C'est juste des données test pour un projet que j'ai créer rapidement pour tester l'export vers excel avec EPPLUS. C'est un exemple "bateau" pour garder une discrétion sur le code de l'application de l'entreprise où je travaille. J'aurai adapté le code après.
    Tu peux garder secret le code de ton entreprise tout en mettant une classe. L'intérêt c'est que tu peux ne récupérer qu'une seule fois les PropertyInfo de ton type et les utiliser sur tous les objets de ta collection plutôt que de les redemander à chaque fois.

    Une classe décrivant une personne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public class Person
    {
        public int Id { get; set; }
        public string LastName { get; set; }
        public string FirstName { get; set; }
        public string Email { get; set; }
    }
    Une méthode générique chargeant une liste objets dans une DataTable :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    public static DataTable Load<T>(IEnumerable<T> source)
    {
        var props = typeof(T).GetProperties(BindingFlags.Instance | BindingFlags.Public);
        var table = new DataTable(typeof(T).Name);
        foreach (var prop in props) table.Columns.Add(prop.Name);
        foreach (var item in source)
        {
            var row = table.NewRow();
            foreach (var prop in props) row[prop.Name] = prop.GetValue(item);
            table.Rows.Add(row);
        }
        table.AcceptChanges();
        return table;
    }

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

Discussions similaires

  1. [Débutant] Récupérer le numéro du rang d'un élément dans un tableau
    Par PapouMAC dans le forum VB.NET
    Réponses: 4
    Dernier message: 03/01/2016, 21h20
  2. récupérer un nombre de champs aléatoire
    Par mdr_cedrick dans le forum Langage
    Réponses: 1
    Dernier message: 28/04/2008, 10h10
  3. Réponses: 2
    Dernier message: 11/12/2006, 12h38
  4. Récupérer un nombre dans un champs texte
    Par mandou36 dans le forum Access
    Réponses: 18
    Dernier message: 05/09/2006, 19h11
  5. Réponses: 1
    Dernier message: 08/11/2005, 14h40

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