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 :

Affecter valeur d'une donnée membre sous condition [Débutant]


Sujet :

C#

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Octobre 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2013
    Messages : 7
    Par défaut Affecter valeur d'une donnée membre sous condition
    Bonjour,

    J'utilise l'objet suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
            public class MonObjet
            {
                public string LeString { get; set; }
                public double LeDouble { get; set; }
     
            }
    Je crée des instances de mon objet à partir d'une boucle sur une datatable, de la facçon suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     for(int i=0;i<DataSet.Tables["LATABLESOURCE"].Rows.Count;i++)
                {
                    MonObjet item = new MonObjet
                    {
                       LeString = (string)DataSet.Tables["LATABLESOURCE"].Rows[i][1],
                       LeDouble = (double)DataSet.Tables["LATABLESOURCE"].Rows[i][2],
     
     
                    };
     
     
                }
    Mon problème est le suivant :
    Le champs du Dataset contenant des données de type double peut être null. Lorsque tel est le cas, une erreur se produit logiquement (cast invalide) lorsque l'on essaye d'affecter une valeur à "LeDouble".

    Comment insérer une condition du type : si "DataSet.Tables["LATABLESOURCE"].Rows[i][2] ==null alors LeDouble=0", en gardant la même construction?

    D'avance merci.

  2. #2
    Membre éclairé

    Profil pro
    Chef de Projet / Développeur
    Inscrit en
    Juin 2002
    Messages
    620
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de Projet / Développeur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2002
    Messages : 620
    Par défaut
    Essaie ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    LeDouble = DataSet.Tables["LATABLESOURCE"].Rows[i][2] == null ? (double)DataSet.Tables["LATABLESOURCE"].Rows[i][2], 0;
    (je suis en train de me demander si c'est pas "is DBNull" et non " == null" )

    Perso, je me suis une fonction static dans une classe d'utilitaire qui fait ce genre de boulot et qui donne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    LeDouble  = gtools.SiDoubleDBNull( MonDataReader["MON_CHAMP"], 0 );

  3. #3
    Membre Expert
    Avatar de Pongten
    Homme Profil pro
    IT Analyst & Software Developer
    Inscrit en
    Juin 2002
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : IT Analyst & Software Developer
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Juin 2002
    Messages : 1 173
    Par défaut
    Personnellement, depuis que j'y ai gouté, je préfère utiliser la méthode d'extension Field<>().

    Exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    LeDouble = DataSet.Tables["LATABLESOURCE"].Rows[i].Field<Double?>("NOMCOLONNE").GetValueOrDefault(0);
    Comme c'est une méthode générique, tu précise le type souhaité (ici un double nullable puisque c'est le cas de ta colonne), et comme tu veux le placer dans un double, plus qu'à utiliser la méthode GetValueOrDefault() des types nullables pour déterminer ta valeur par défaut.

  4. #4
    Membre Expert
    Avatar de Pongten
    Homme Profil pro
    IT Analyst & Software Developer
    Inscrit en
    Juin 2002
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : IT Analyst & Software Developer
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Juin 2002
    Messages : 1 173
    Par défaut
    Citation Envoyé par vanquish Voir le message
    (je suis en train de me demander si c'est pas "is DBNull" et non " == null" )
    C'est même "== DBNull.Value" je pense

  5. #5
    Membre régulier
    Homme Profil pro
    Inscrit en
    Octobre 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2013
    Messages : 7
    Par défaut
    Merci beaucoup pour vos réponses.
    J'ai opté pour la méthode Field<T>() que je ne connaissais pas.
    Bonne journee

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

Discussions similaires

  1. [XL-2010] Report de données sur une autre feuille, sous condition
    Par colinez dans le forum Excel
    Réponses: 3
    Dernier message: 15/06/2015, 16h26
  2. [XL-MAC 2011] Afficher une donnée aléatoire sous condition
    Par Donv29 dans le forum Excel
    Réponses: 1
    Dernier message: 17/03/2012, 12h17
  3. [AC-2003] Cacher certaine valeurs d'une liste déroulante sous condition
    Par Williamm dans le forum VBA Access
    Réponses: 2
    Dernier message: 20/07/2011, 13h53
  4. Réponses: 1
    Dernier message: 26/09/2007, 17h16
  5. Réponses: 4
    Dernier message: 06/08/2007, 17h50

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