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

Composants Java Discussion :

Convertir les valeurs d'un jTable


Sujet :

Composants Java

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2014
    Messages : 13
    Points : 9
    Points
    9
    Par défaut Convertir les valeurs d'un jTable
    Bonsoir,

    Je cherche à lire des données contenues dans un jTable et les convertir en “double” pour pouvoir les utiliser par la suite. J’ai essayé de faire comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    for (int i= 1; i< Nrow;i++){
              Object vall0= jTable1.getValueAt(i, 0);
               double  vall1 = Double.valueOf(String.valueOf(jTable1.getValueAt(i, 1)));
               double  vall2 = Double.valueOf(String.valueOf(jTable1.getValueAt(i, 2)));
              double  vall3 = Double.valueOf(String.valueOf(jTable1.getValueAt(i, 3)));
           // Code de calcul
    }
    Pour la valeur vall0, il n’y a pas d’erreur . Pour les autres, un message d’erreur s’affiche :
    Exception in thread "AWT-EventQueue-0" java.lang.NumberFormatException: For input string: "null"


    Merci d'avance

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Visiblement il n'y a rien dans les colonne indiquées (null), donc le String.ValueOf retourne "null" et ensuite le Double.valueOf coince quand il doit parser la chaine "null" qui n'est pas un nombre.

    Tu pourrais t'éviter accessoirement ces emmerdes en stockant directement des double dans ta JTable, ce qui deviendrais:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Double vall1 = (Double)jTable1.getValueAt(i, 1);
    //....

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2014
    Messages : 13
    Points : 9
    Points
    9
    Par défaut
    Merci pour votre réponse
    Je rencontre ce problème lorsque la jTAble1 est remplie à partir d’un fichier téléchargé en effectuant un mouseCliked sur un jTree. Si non la conversion fonctionne très bien et le programme tourne quand j’affecte les données au jTable sans passer par le jTree mais cela m'arrange pas :/ .
    PS : j’ai essayé de faire la conversion suivant différentes manières y compris celle que vous m’avez montrée.

  4. #4
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    ben si c'est null, c'est null, tu pourra pas inventer la donnée. Si il est censé y avoir une données là, c'est que t'as un problème ailleurs quand tu remplis les données, parce qu'il n'y a pas de donnée.

  5. #5
    Futur Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2015
    Messages : 15
    Points : 8
    Points
    8
    Par défaut
    Vous dites que vous n’avez ce problème que lors du remplissage de la table à partir d’un jTree. Vous devez peut être vérifier l’étape qui permet l’accès au fichier.

  6. #6
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2014
    Messages : 13
    Points : 9
    Points
    9
    Par défaut
    Bonjour à tous,
    Voici le code que j'utilise pour remplir la jTable1 à partir de jTree1

    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
     
    private void jTree1MouseClicked(java.awt.event.MouseEvent evt) {                                    
     
         Object[] X =  jTree1.getSelectionPath().getPath();
     
        if(X.length == 5)
        {
            String name = X[X.length -1].toString();
            DataTable DT;
                try {
                    DT = new DataTable(DB, "select * from fiche where id='"+name+"'");
                    String[] doc = DT.getRow(0).GetColumn(2).split("\n");
     
                    String[] titres = {"Direction","Intensité de trafic(Erlang)","Congestion","N Voies bloquées","NDV","Taux de probabilité"};
                    Object[][] data = new Object[doc.length][6];
     
                    for(int i = 0 ; i < doc.length ; i++)
                    {
                        String[] line = doc[i].split(";");
                        data[i] = line;
                    }
     
                    TableModel mm = new logiciel.TableModel(data, titres);
                    jTable1.setModel(mm);
     
                } catch (SQLException ex) {
                    Logger.getLogger(resultat.class.getName()).log(Level.SEVERE, null, ex);
                }
     
        }
     
    }

  7. #7
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2014
    Messages : 13
    Points : 9
    Points
    9
    Par défaut
    salut,
    Le problème est résolu. En effet, il y avait une erreur lors du remplissage de la table.
    Merci à tous

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 02/05/2015, 11h34
  2. Réponses: 5
    Dernier message: 26/06/2009, 17h38
  3. Convertir les noms de constantes Excel en valeurs numériques
    Par Martin_77 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 31/07/2008, 09h12
  4. Comment convertir les données extraite d'une jtable ?
    Par jouidos dans le forum Langage
    Réponses: 2
    Dernier message: 11/12/2006, 09h35
  5. [JTable]Modifier les valeurs en temps réel
    Par yoshï dans le forum Composants
    Réponses: 11
    Dernier message: 02/06/2006, 17h11

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