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

Macros et VBA Excel Discussion :

Arrondi non conservé


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 7
    Par défaut Arrondi non conservé
    Bonjour,

    je suis confronté à un problème avec une de mes macros VBA que je ne parviens pas à élucider.

    Mon code est le suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Dim tableau(3) As Single    
    ...
    tableau(0) = Round(ActiveWorkbook.Sheets("a").Range("X16").Value, 1)
    tableau(1) = Round(ActiveWorkbook.Sheets("b").Range("X16").Value, 1)
    tableau(2) = Round(ActiveWorkbook.Sheets("c").Range("X16").Value, 1)
    Range("d").Resize(1, 3) = tableau
    En l'occurrence, en ActiveWorkbook.Sheets("b").Range("X16"), j'ai 37,599998474121 .
    Dans tableau(1) je retrouve comme voulu 37.6.
    Mais dans ma feuille Excel, en Range("d").Offset(0,1), je me retrouve à nouveau avec 37,599998474121.

    Aussi, je m'arrache les cheveux et ne comprends pas !!

    Auriez-vous une explication et un remède ?

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Par défaut
    Bonsoir,

    Déclare ton tableau en type "Double" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Dim tableau(3) As Double
    Hervé.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 7
    Par défaut
    Merveilleux !!

    Pour vivre moins bête : pourquoi la simple précision posait-elle problème ?...

  4. #4
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Par défaut
    A cause de la méthode de conversion en Single.
    VBA part d'un double et tronque mantisse et exposant, ce qui donne une aproximation correcte à quelques chiffres après la décimale.
    Je vais voir si je retrouve l'explication complète.

    En voici une:
    http://www.developpez.net/forums/d35...a/#post2317362
    N'oubliez pas de cliquer sur quand vous avez obtenu ou trouvé vous-même la réponse à votre question.
    Si vous trouvez seul, pensez à poster votre solution. Elle peut servir à d'autres!
    Pensez aussi à voter pour les réponses qui vous ont aidés.
    ------------
    Je dois beaucoup de mes connaissances à mes erreurs!

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 14/10/2007, 20h00
  2. [ASP.NET 2.0 / C#]Cookie non conservé.
    Par maniaco_jazz dans le forum ASP.NET
    Réponses: 4
    Dernier message: 05/07/2007, 13h55
  3. Réponses: 3
    Dernier message: 27/06/2007, 22h44
  4. Problème de Tableau (non conservé sous ie)
    Par dj-julio dans le forum Langage
    Réponses: 12
    Dernier message: 23/12/2005, 11h19
  5. Arrondie non voulu
    Par Toff !!!!! dans le forum Access
    Réponses: 5
    Dernier message: 27/09/2005, 10h13

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