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 :

ArgumentException et valeur inférieure dans un range


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    249
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2007
    Messages : 249
    Par défaut ArgumentException et valeur inférieure dans un range
    Salut à toutes et à tous,

    Soit ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    /// <summary>
                /// Recherche dans le DataSet les lignes opposées à la ligne sélectionnée
                /// </summary>
                /// <param name="ligneRow">Ligne dont on cherche les lignes opposées</param>
                /// <param name="dataSet">DataSet dans lequel on cherche les lignes opposées</param>
                /// <returns>Lignes opposées</returns>
                public DataSetParcelles.LigneRow[] GetOpposedLines(DataSetParcelles.LigneRow ligneRow, DataSetParcelles dataSet)
                {
                    if (dataSet == null || dataSet.Ligne == null || string.IsNullOrEmpty(ligneRow.NumeroPoint1) || string.IsNullOrEmpty(ligneRow.NumeroPoint2))
                        return null;
                        return (DataSetParcelles.LigneRow[])dataSet.Ligne.DefaultView.Table.Select(string.Format("NumeroPoint1 = '{0}' AND NumeroPoint2 = '{1}'", ligneRow.NumeroPoint2, ligneRow.NumeroPoint1));
                }
    Elle me retourne parfois (de manière qui semble aléatoire, mais est-ce réellement aléatoire ?) l'erreur
    "L'exception ArgumentException n'a pas été gérée par le code utilisateur
    Min (15101) doit être inférieur ou égal à max (-1) dans un objet Range."
    sur la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    return (DataSetParcelles.LigneRow[])dataSet.Ligne.DefaultView.Table.Select(string.Format("NumeroPoint1 = '{0}' AND NumeroPoint2 = '{1}'", ligneRow.NumeroPoint2, ligneRow.NumeroPoint1));
    or le select de la table devrait bien retourner une ligne.
    Si je ferme l'application et la redémarre, cette ligne passe sans problème, et après un certains temps, elle finira par me retourner cette erreur avec d'autres valeurs, qui passeront aussi si je redémarre l'application.

    Je veux bien gérer l'erreur, mais pour la gérer il faudrait avant tout que je la comprenne, ce qui pour le moment est loin d'être le cas. Donc actuellement le ne sais pas comment, ni où la gérer.

    Si qqn comprend d'où ça peut venir, je vous remercie de vos z'avis z'avisés.

    JM

  2. #2
    Membre chevronné
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2008
    Messages
    381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Août 2008
    Messages : 381
    Par défaut
    Tu as essayé de découper ta ligne en plusieurs expressions? De cette manière du pourrait cibler exactement l'instruction qui cause cette exception.

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    249
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2007
    Messages : 249
    Par défaut
    Je suis remonté jusqu'à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataSet.Ligne.Select(string.Format("NumeroPoint1 = '{0}' AND NumeroPoint2 = '{1}'", ligneRow.NumeroPoint2, ligneRow.NumeroPoint1));
    et déjà là ça "merdouille".
    Mais ce qui me rend le plus perplexe c'est que si je redémarre l'appli ça passe.
    On dirait que le pbl ne vient pas directement de là, parce que la ligne existe bel et bien dans la table, alors pourquoi le select boguerait ?
    Je trouve qu'on dirait que l'erreur sort là mais ne se situe pas là.

  4. #4
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    249
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2007
    Messages : 249
    Par défaut
    A plusieurs endroits je trouve des gens qui ont été confrontés à cette erreurs et il semblerait que dans tous les cas c'est quand les ' n'ont pas été mis de part et d'autre d'une valeur. Or dans mon cas les ' sont bien présents de part et d'autres des NumeroPoint1 et NumeroPoint2.

    Quelqu'un comprendrait-il ce qu'il pourrait bien se passer ?

  5. #5
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2003
    Messages
    274
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Luxembourg

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

    Informations forums :
    Inscription : Décembre 2003
    Messages : 274
    Par défaut
    Idee en lisant ton code et tes commentaires:

    N'y aurait-il pas des apostrophes dans tes valeurs? Si oui alors ils annulent probablement ceux que tu place toi meme deja dans ta string -> ils generent au passage une erreur avec le nombre impair d'apostrophes par exemple.

  6. #6
    Membre chevronné
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    231
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2008
    Messages : 231
    Par défaut
    Es ce que tu sais d'où vient

Discussions similaires

  1. Réponses: 5
    Dernier message: 18/06/2015, 12h48
  2. Réponses: 2
    Dernier message: 24/06/2014, 08h52
  3. [XL-2007] Compter le nombre de valeurs uniques dans un range (macro)
    Par richard_sraing dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 19/09/2012, 09h42
  4. [Débutant] le rang des valeurs répétées dans un vecteur
    Par Minouchka dans le forum MATLAB
    Réponses: 4
    Dernier message: 21/03/2010, 18h02

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