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

API standards et tierces Java Discussion :

[Apache POI] Problème d'arrondi à la lecture de nombres dans Excel


Sujet :

API standards et tierces Java

  1. #1
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur Java
    Inscrit en
    Juillet 2015
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Juillet 2015
    Messages : 3
    Points : 1
    Points
    1
    Par défaut [Apache POI] Problème d'arrondi à la lecture de nombres dans Excel
    Bonjour,

    Mon appli utilise la librairie Apache POI 3.10-FINAL et je rencontre un (énorme) problème à la lecture de nombres dans un fichier Excel puisque les nombres sont modifiés (!).
    En effet, dans mon tableau j'ai la valeur 0.001306 mais le résultat de cell.getNumericCellValue() me renvoie 0.0013059999999999999 ! De la même façon, la valeur 2587441349.95676 se transforme en 2.5874413499567585E9.
    J'ai essayé de convertir le type de la cellule avant de la lire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    cell.setCellType(Cell.CELL_TYPE_STRING);
    cell.getStringCellValue();
    Mais si la valeur n'est pas modifiée, c'est le formatage qui l'est : 0.001306 devient 1.306E-3 or je ne peux pas retransformer le formatage car la seule règle est qu'il faut que ce soit stocké/affiché comme cela l'était dans le fichier excel (si l'utilisateur rentre des valeurs sous la forme 0.001306 parfois et d'autres 1.306E-3, il le peut)
    J'ai également essayé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ((XSSFCell) cell).getRawValue();
    mais là... ce qui était précédemment -2.3600000000000001E-3 devient 131 (?!?!).

    J'ai essayé de faire des modifications dans la feuille excel, en changeant le type des cellules (numérique avec x chiffres après la virgule, ou texte, ou...) mais ça ne change rien. Il n'y a que lorsque je rajoute une simple quote avant un nombre qu'il est vraiment lu comme une chaine de caractère (et donc pas modifié).

    Je suis étonnée de ne pas trouver grand chose concernant ce problème dans google...? Personne n'a jamais rencontré ce souci ?

  2. #2
    Membre averti
    Avatar de smarlytomtom
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Novembre 2014
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2014
    Messages : 139
    Points : 373
    Points
    373
    Billets dans le blog
    1
    Par défaut
    salut !
    Est-ce que ces valeurs sont tirées d'une formule ? Pour ce qui est de la conversion en chaîne de caractère je penses que ce n'est pas une très bonne idée !
    J'ai manipulé beaucoup de cellules avec des formules et je n'ai jamais eu ce problème ! est-il possible d'avoir ton code ?
    Thomas Gredin.
    Développeur Unity 3D/VR

    Mon site personnel : http://thomasgredin.com/fr
    Mon portfolio : http://thomasgredin.com/fr/portfolio

  3. #3
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur Java
    Inscrit en
    Juillet 2015
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Juillet 2015
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par smarlytomtom Voir le message
    salut !
    Est-ce que ces valeurs sont tirées d'une formule ? Pour ce qui est de la conversion en chaîne de caractère je penses que ce n'est pas une très bonne idée !
    J'ai manipulé beaucoup de cellules avec des formules et je n'ai jamais eu ce problème ! est-il possible d'avoir ton code ?
    Merci pour ta réponse
    Hénon, pas de formule, des nombres saisis à la main - c'est d'ailleurs bien ce qui me désespère.
    En fait, j'ai essayé de convertir le type de la cellule parce que de toutes façons, toutes les données sont ensuite passées en String (!) (j'avoue que je ne suis pas allée voir comment les nombres étaient re-convertis ensuite pour être mis en BD, puisque ça foire dès la lecture) :
    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
      public List<String> readRow(final Row row, Row descRow) {
        List<String> listOfAttributes = new ArrayList<String>();
     
        Iterator<Cell> cellIterator = null;
        if (descRow != null) {
          cellIterator = descRow.cellIterator();
        } else {
          cellIterator = row.cellIterator();
        }
     
        while (cellIterator.hasNext()) {
          Cell descCell = cellIterator.next();
          Cell cell = null;
          if (descRow != null) {
       int columnIndex = descCell.getColumnIndex();
            cell = row.getCell(columnIndex);
          } else {
            cell = descCell;
          }
          if (cell == null) {
            listOfAttributes.add(null);
          } else if (cell.getCellType() == Cell.CELL_TYPE_BOOLEAN) {
            listOfAttributes.add(String.valueOf(cell.getBooleanCellValue()));
          } else if (cell.getCellType() == Cell.CELL_TYPE_STRING) {
            listOfAttributes.add(cell.getStringCellValue());
          } else if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {
            listOfAttributes.add(String.valueOf(cell.getNumericCellValue()));
          } else {
            listOfAttributes.add(null);
          }
     
        }
        return listOfAttributes;
      }
    et j'ai donc tenté des trucs comme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {
              listOfAttributes.add(((XSSFCell) cell).getRawValue());
     }
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {
              cell.setCellType(Cell.CELL_TYPE_STRING);
              listOfAttributes.add(String.valueOf(cell.getStringCellValue()));
    }
    ça ne pourrait pas s'expliquer par des options du côté de la feuille Excel...?

  4. #4
    Membre averti
    Avatar de smarlytomtom
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Novembre 2014
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2014
    Messages : 139
    Points : 373
    Points
    373
    Billets dans le blog
    1
    Par défaut
    C'est vraiment étrange j'ai regardé ton code mais aucune erreur ne m'a sauté au visage ...
    Regarde le format de tes cellules dans Excel en faisant un clique droit dessus et un "Format cells" !
    Il est possible que ce qui est affiché ne reflète pas la réalité des données, excel force peut être ton nombre de chiffres après la virgule ou un truc comme ça !
    Je ne promet rien dans ce que j'avance mais c'est une possibilité qu'il ne faut pas négliger !
    Thomas Gredin.
    Développeur Unity 3D/VR

    Mon site personnel : http://thomasgredin.com/fr
    Mon portfolio : http://thomasgredin.com/fr/portfolio

  5. #5
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Cell.getNumericValue() retour un double, un type dont le stockage est limité en taille (8 octets), donc en nombre de valeurs différentes représentables, qui permet de représenter des nombres à virgules flottantes. Il y a une infinité de valeurs entre 1.5 et 1.6 par exemple : le type double ne peut tout simplement pas représenter un nombre infini de valeurs. Il fait donc une approximation.

    On peut obtenir la représentation exacte du nombre (tel que excel l'affiche) par un DataFormatter, ce qui revient à faire la conversion en String que tu essayais de faire.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  6. #6
    Membre averti
    Avatar de smarlytomtom
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Novembre 2014
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2014
    Messages : 139
    Points : 373
    Points
    373
    Billets dans le blog
    1
    Par défaut
    Je ne connaissais pas ce DataFormatter ! Merci pour le tuyau joel, j'en aurai surement besoin un jour !
    Thomas Gredin.
    Développeur Unity 3D/VR

    Mon site personnel : http://thomasgredin.com/fr
    Mon portfolio : http://thomasgredin.com/fr/portfolio

  7. #7
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur Java
    Inscrit en
    Juillet 2015
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Juillet 2015
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par joel.drigo Voir le message
    Salut,

    Cell.getNumericValue() retour un double, un type dont le stockage est limité en taille (8 octets), donc en nombre de valeurs différentes représentables, qui permet de représenter des nombres à virgules flottantes. Il y a une infinité de valeurs entre 1.5 et 1.6 par exemple : le type double ne peut tout simplement pas représenter un nombre infini de valeurs. Il fait donc une approximation.

    On peut obtenir la représentation exacte du nombre (tel que excel l'affiche) par un DataFormatter, ce qui revient à faire la conversion en String que tu essayais de faire.
    ...tu m'as sauvé ma vie, merci infiniment

Discussions similaires

  1. Apache POI: récupérer les noms de colonnes d'un fichier excel
    Par cedy-kassy dans le forum Général Java
    Réponses: 2
    Dernier message: 25/03/2014, 12h35
  2. Lecture de données dans Excel
    Par kurul1 dans le forum MATLAB
    Réponses: 4
    Dernier message: 16/06/2009, 14h39
  3. Réponses: 3
    Dernier message: 15/03/2007, 12h36
  4. problème avec un telechargement d'un .csv dans Excel
    Par olosta dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 03/05/2006, 03h29
  5. Problème lecture de nombre dans un fichier en c++
    Par knecmotet dans le forum C++
    Réponses: 1
    Dernier message: 28/10/2004, 15h48

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