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 :

java.lang.NumberFormatException: For input string: "1 629.500"


Sujet :

Langage Java

  1. #1
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut java.lang.NumberFormatException: For input string: "1 629.500"
    Bonjour les amis,
    Voici mon problème:
    lorsque je lie le contenu d'une cellule (fichier excel) qui représente un montant et je la place dans une variable de type float, j'ai l"'erreur suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    java.lang.NumberFormatException: For input string: "1 629.500
    Voici ma portion de code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    float s6_Montant=0;
     
    if(ligne.getCell(4).getCellType()==HSSFCell.CELL_TYPE_NUMERIC)	            	      
    s6_Montant=(float) ligne.getCell(4)
     
    else if(ligne.getCell(4)).getCellType()== HSSFCell.CELL_TYPE_STRING) s6_Montant=Float.valueOf((ligne.getCell(4)).getStringCellValue()).replace(',','.').replaceAll(" ","").trim());

    Veuillez m'aidez svp, j'ai essayé de supprimer les espaces et remplacer la virgule par un point, mais en vain.

    Merci d'avance!!

  2. #2
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,


    Utilises ceci pour remplacer les espaces :
    Ce qui représente plusieurs types de blanc, dont l'espace "insécable" qui est différent de l'espace standard...


    a++

  3. #3
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    Merci pour votre réponse adiGuba, mais j'ai déja essayé cela (replaceAll("\\s","")), mais en vain

  4. #4
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Dans ce cas quel est le message d'erreur exacte ?


    a++

  5. #5
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    le voila :

    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
     
    java.lang.NumberFormatException: For input string: "1*629.500"
    	at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:1224)
    	at java.lang.Float.valueOf(Float.java:388)
    	at com.ram.rve.metier.rve.Chargement.chargerFichier(Chargement.java:190)
    	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    	at java.lang.reflect.Method.invoke(Method.java:597)
    	at org.apache.el.parser.AstValue.invoke(AstValue.java:191)
    	at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:276)
    	at org.apache.jasper.el.JspMethodExpression.invoke(JspMethodExpression.java:68)
    	at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:77)
    	at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:91)
    	at javax.faces.component.UICommand.broadcast(UICommand.java:383)
    	at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:447)
    	at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:752)
    	at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:97)
    	at com.sun.faces.lifecycle.LifecycleImpl.phase(LifecycleImpl.java:251)
    	at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:117)
    	at javax.faces.webapp.FacesServlet.service(FacesServlet.java:244)
    	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    	at org.apache.myfaces.webapp.filter.ExtensionsFilter.doFilter(ExtensionsFilter.java:349)
    	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
    	at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:857)
    	at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
    	at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
    	at java.lang.Thread.run(Thread.java:619)

  6. #6
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    Je vous signale que l'erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    at com.ram.rve.metier.rve.Chargement.chargerFichier(Chargement.java:190)
    correspond à la ligne suivante de ma classeChargement.java:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    s6_Montant=Float.valueOf((ligne.getCell(deduirePos(marche.getPosmontant())[0]).getStringCellValue()).replace(',','.').replaceAll("\\s","").trim());

  7. #7
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Ben... Tu as une étoile dans ta chaine : "1*629.500"
    Normal que ca plante il faudra aussi la supprimer...


    a++

  8. #8
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    Dans la section des messages d'erreur, l'étoile ne parait pas, mais en faisant copier pour coller dans ce post ca se voit, je crois que c'est juste une erreur, sinon en ajoutant replaceAll("*",""), ca ne change rien, mais j'ai l'erreur suivante, que normalement ne doit pas avoir lieu :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    java.util.regex.PatternSyntaxException: Dangling meta character '*' near index 0
    Merci d'avance!!

  9. #9
    Rédacteur/Modérateur
    Avatar de Logan Mauzaize
    Homme Profil pro
    Architecte technique
    Inscrit en
    Août 2005
    Messages
    2 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Transports

    Informations forums :
    Inscription : Août 2005
    Messages : 2 894
    Points : 7 084
    Points
    7 084
    Par défaut
    Normal l'étoile est un caractère spécial dans les expressions régulières tu dois le protéger (ex: "\\*")

  10. #10
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    Oui c'est vrai, j'ai oublié de protéger le caractère spécial; mais en le faisant maintenant replaceAll("\\*",""), je recois l'erreur de départ:
    <code>
    java.lang.NumberFormatException: For input string: "1*629.500"
    </code>

    C'est vraiment bizarre, j'ai supprimer les espace, et aussi les étoiles, j'ai remplacer la virgule avec le point, mais toujours le meme probleme

    NB: Y'a comme meme quelque choses qui cloche: c'est que en supprimant l'espace, et je met un println, je vois que l'espace perssiste !!!!

  11. #11
    Rédacteur/Modérateur
    Avatar de Logan Mauzaize
    Homme Profil pro
    Architecte technique
    Inscrit en
    Août 2005
    Messages
    2 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Transports

    Informations forums :
    Inscription : Août 2005
    Messages : 2 894
    Points : 7 084
    Points
    7 084
    Par défaut
    Tu peux nous mettre la ligne de transformation du float et celle du println ?

  12. #12
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    Les voila :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    String rr=(ligne.getCell(4).getStringCellValue()).replace(',','.').replaceAll("\\*","").replaceAll("\\s","").trim();
    System.out.println(rr);
    s6_Montant=Float.valueOf(rr);

  13. #13
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    En fait, j'ai aussi essayé s6_Montant=Float.parseFloat(rr); mais en vain toujours le meme problème !!!

  14. #14
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Le plus simple serait d'afficher ce que tu as dans ta chaine exactement, avant tous ces remplacements, et caractère par caractère :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    String s = ligne.getCell(4).getStringCellValue();
    System.out.println(s);
    for (char c : s.toCharArray()) {
    	System.out.printf("\t'%c'[%x]%n", c, (int)c);
    }

    a++

  15. #15
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    Bonne idée, et voici le résultat du code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    String rr=(ligne.getCell(deduirePos(marche.getPosmontant())[0]).getStringCellValue());
    System.out.println(rr);	 
    for (char c : rr.toCharArray()) {
        System.out.printf("\t'%c'[%x]%n", c, (int)c);
    }
    s6_Montant=Float.parseFloat(rr);
    1*629,500
    '1'[31]
    '*'[a0]
    '6'[36]
    '2'[32]
    '9'[39]
    ','[2c]
    '5'[35]
    '0'[30]
    '0'[30]
    ' '[20]

    java.lang.NumberFormatException: For input string: "1*629,500"

    C'est vraiment bizarre l'espace existe belle et bien dans la chaine de caractère, et après sa suppression, seule l'espace dernier est supprimé, et celui entre le chifre 2 et le chiffre 6 persiste !!! :


    1*629.500
    '1'[31]
    '*'[a0]
    '6'[36]
    '2'[32]
    '9'[39]
    '.'[2e]
    '5'[35]
    '0'[30]
    '0'[30]

  16. #16
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    hhh, dans Eclipse je vois un espace entre le chiffre 6 et le chiffre 1, et lorsque je copie et je colle dans ce post je vois apparaitre une etoile à la place. Je crois que c'est un prblème de codage !!!

  17. #17
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par le_misterioso Voir le message
    hhh, dans Eclipse je vois un espace entre le chiffre 6 et le chiffre 1, et lorsque je copie et je colle dans ce post je vois apparaitre une etoile à la place. Je crois que c'est un prblème de codage !!!
    Le forum supprime certains caractères et les remplaces par des '*'.

    C'est un espace insécable (code \u00a0). Je pensais que le \s du Pattern le prenais en compte mais cela ne semble pas être le cas. Tu peux faire un remplacement manuel ou mieux inverser ton traitement, c'est à dire supprimer tout ce qui n'est pas chiffre ou point :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .replace(',','.').replaceAll("[^0-9.]", "");
    a++

  18. #18
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    Avez-vous d'autres idées??
    Merci et désolé pour le dérangement !

  19. #19
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    121
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 121
    Points : 37
    Points
    37
    Par défaut
    Alors là, mon problème est bien résolu. Merci à vous tous mes amis, et surtout toi adiGuba

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

Discussions similaires

  1. java.lang.NumberFormatException: For input string: ""
    Par momjunior dans le forum AWT/Swing
    Réponses: 4
    Dernier message: 24/04/2019, 00h50
  2. java.lang.NumberFormatException: For input string:
    Par leara500 dans le forum Langage
    Réponses: 3
    Dernier message: 29/04/2013, 19h36
  3. Réponses: 0
    Dernier message: 06/05/2010, 10h43
  4. Réponses: 5
    Dernier message: 20/11/2009, 13h18
  5. Réponses: 1
    Dernier message: 15/01/2009, 11h22

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