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

Langage Java Discussion :

problème de conversion


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Juillet 2006
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 100
    Par défaut problème de conversion
    Je voudrais pouvoir faire des calculs sur des strings (première_touche_pressed, deuxième_touche_pressed ....)
    mais ca ne fonctionne pas
    j'ai essayé d'utiliser la fonction parseLong mais j'ai des exceptions

    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 void Differences_press(String id) {
            facade = new FacadeJDBC();
            List <List <String>> resultat = facade.requete("SELECT * FROM Mesure_nom WHERE (Mesure_nom.id)=\'"+id+"\'");
            List<String> result = resultat.get(0);
            String première_touche_pressed = result.get(1);
            String deuxième_touche_pressed = result.get(2);
            String troisième_touche_pressed = result.get(3);
            String quatrième_touche_pressed = result.get(4);
            String cinquième_touche_pressed = result.get(5);
            String sixième_touche_pressed = result.get(6);
            String septième_touche_pressed = result.get(7);
            String huitième_touche_pressed = result.get(8);
                   }
    Y a t'il une solution pour soustraire deux strings ?
    Merci

  2. #2
    Membre éprouvé Avatar de BainE
    Inscrit en
    Mai 2004
    Messages
    1 327
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 1 327
    Par défaut
    SAlut,

    pourquoi ne pas ffaire directement un getDouble sur la base ?

    Sinon pourait tu nous montrer le format des chaine remontés ainsi que l erreur genere par le parseDouble

  3. #3
    Membre émérite
    Profil pro
    Architecte technique
    Inscrit en
    Mars 2002
    Messages
    966
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Mars 2002
    Messages : 966
    Par défaut
    Sous oracle (je ne sais pas si c'est ton cas), tu peux utiliser la fonction sql:

    TO_NUMBER (chaine, pattern)

    A+

  4. #4
    Membre confirmé
    Inscrit en
    Juillet 2006
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 100
    Par défaut
    Voici ce que j'ai réalisé avec la fonction parselong

    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
    33
    34
    35
    36
    37
    38
    39
     
        public void Differences_press(String id) {
            facade = new FacadeJDBC();
            List <List <String>> resultat = facade.requete("SELECT * FROM Mesure_nom WHERE (Mesure_nom.id)=\'"+id+"\'");
            //System.out.println(resultat);
            List<String> result = resultat.get(0);
            String première_touche_pressed = result.get(1);
            String deuxième_touche_pressed = result.get(2);
            String troisième_touche_pressed = result.get(3);
            String quatrième_touche_pressed = result.get(4);
            String cinquième_touche_pressed = result.get(5);
            String sixième_touche_pressed = result.get(6);
            String septième_touche_pressed = result.get(7);
            String huitième_touche_pressed = result.get(8);
            long[] resul = new long[8];
            long première_touche_press = Long.parseLong(première_touche_pressed);
            long deuxième_touche_press = Long.parseLong(deuxième_touche_pressed);
            long troisième_touche_press = Long.parseLong(troisième_touche_pressed);
            long quatrième_touche_press = Long.parseLong(quatrième_touche_pressed);
            long cinquième_touche_press = Long.parseLong(cinquième_touche_pressed);
            long sixième_touche_press = Long.parseLong(sixième_touche_pressed);
            long septième_touche_press = Long.parseLong(septième_touche_pressed);
            long huitième_touche_press = Long.parseLong(huitième_touche_pressed);
            resul[0] = première_touche_press;
            resul[1] = deuxième_touche_press;
            resul[2] = troisième_touche_press;
            resul[3] = quatrième_touche_press;
            resul[4] = cinquième_touche_press;
            resul[5] = sixième_touche_press;
            resul[6] = septième_touche_press;
            resul[7] = huitième_touche_press;
            int res =0;
            long[] resu = new long[8];
            for (test1 = 0; test1 < test - 1; test1++){
                resu[res] = resul[test1+1]-resul[test1];
                System.out.println(resu[res]);
                res = res + 1;
            }            
        }
    quand je l'exécute, ca me renvoi une exception :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Exception in thread "AWT-EventQueue-0" java.lang.NumberFormatException: For input string: "1170664245845.0000"

  5. #5
    Membre émérite
    Profil pro
    Architecte technique
    Inscrit en
    Mars 2002
    Messages
    966
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Mars 2002
    Messages : 966
    Par défaut
    L'erreur semble évidente:

    1170664245845.0000 n'est pas un long, long cest :
    1170664245845.

    Utilises un NumberFormat ou un TO_NUMBER avec un pattern comme je te l'ai précisé !!!

    A+

  6. #6
    Membre confirmé
    Inscrit en
    Février 2007
    Messages
    26
    Détails du profil
    Informations forums :
    Inscription : Février 2007
    Messages : 26
    Par défaut
    Utilise un tableau de double et Double.parseDouble a la place de Long.parseLong.

  7. #7
    Membre émérite
    Profil pro
    Architecte technique
    Inscrit en
    Mars 2002
    Messages
    966
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Mars 2002
    Messages : 966
    Par défaut
    Citation Envoyé par mrkzed
    Utilise un tableau de double et Double.parseDouble a la place de Long.parseLong.
    Non il vaut mieux utiliser un NumberFormat ou un TO_NUMBER.

Discussions similaires

  1. problème de conversion de dimension dans BUSINESS OBJECT
    Par greatmaster1971 dans le forum Deski
    Réponses: 4
    Dernier message: 28/04/2014, 13h15
  2. - [CAST ou CONVERT] Problème de conversion de date
    Par Boublou dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 06/07/2004, 14h31
  3. Problème de conversion 3DS->.X
    Par JBernn dans le forum DirectX
    Réponses: 5
    Dernier message: 08/04/2004, 19h08
  4. Problème de conversion unicode
    Par djmalo dans le forum C
    Réponses: 5
    Dernier message: 09/03/2004, 11h48
  5. Réponses: 11
    Dernier message: 02/09/2003, 14h20

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