Fonction arrondi VBA à 2 digits

simdup Messages postés 13 Date d'inscription   Statut Membre Dernière intervention   -  
 Nenette -
Bonjour,
J'aimerais créer une fonction qui arrondi une valeur à 2 digit , par exemple :
pour 2.354 il me donne : 2.3
pour 0.002365 il me donne : 0.0023
Si quelqu'un à une idée d'une solution je suis preneur.
Merci par avance.

Bonne journée


3 réponses

Utilisateur anonyme
 
Bonjour,

tout est incohérent dans ton message, sit tu arrondies à 2 digits alors il y a 2 chiffres dérrière la virgule.

Dans ton premier exemple il y en a 1 et dans le second 4.

Deplus tes deux exemples montrent, non un arrondi ou le n+1ieme digit vaut 5 ou plus alors l'arrondis est au supérieur:
2.354 => 2.4
0.002365 => 0.0024...

Ce que tu montres c'est tronquer.

DOnc formule bien ta question pour avoir une réponse qui te convienne.
En attendant tu peux regarder Round() et Trunc(). (Sais plus si elles existent en VBA)

0
simdup Messages postés 13 Date d'inscription   Statut Membre Dernière intervention  
 
oui en effet ma question n'est pas bien poser, je m'en excuse.
En fait il faudrait que je crée une fonction qui me donne un nombre avec seulement 2 chiffre significatif.
Donc pour : 2.354 => 2.4
0.002365 => 0.0024

Voila j'espere que ma question est bien formulée
Merci par avance
0
Utilisateur anonyme
 
Bon déjà on parle bien d'arrondi.
Maintenant, 2 chiffres significatifs ça veut dire 2 chiffres derrière la virgule.
Ce n'est toujours pas ce que montrent tes deux exemples.

On va essayer.....

Function ArrondiSimdup(Valeur As Double)
    Dim posPoint As Integer
    Dim nbrDecimales As Integer
    Dim val As String
    val = CStr(Valeur) 'on passe en string sinon len() ne donne pas le bon résultat

    posPoint = InStr(val, ".") 'à quel carractère se trouve le point
    nbrDecimales = Len(val) - posPoint 'nombre de chiffres derrière le point

    ArrondiSimdup = Round(Valeur, nbrDecimales - 2) 'arrondi à 2 chiffres de moins qu'existant
End Function


Par contre je n'ai pas traité le cas ou un nombre a moins de 2 décimlaes
0
Nenette
 

Bonjour,

Je ne suis pas d'accord avec Whismeril. la reformulation de simdup est bonne. 2 chiffres significatifs ne signifient ABSOLUMENT PAS 2 décimales. Ce sont des choses TOTALEMENT opposées!

0
Zoul67 Messages postés 1959 Date d'inscription   Statut Membre Dernière intervention   149
 
Bonjour,

La notation ingénieur te permet d'avoir exactement deux chiffres significatifs, mais il y a les puissances de 10 qui apparaissent.
Mais ça m'a donné l'idée d'utiliser le log en base 10...

Sans VBA et par formule, en Excel anglais, ça donne :
=ROUND(A1/POWER(10;INT(LOG10(A1)));1)*POWER(10;INT(LOG10(A1)))
Je pense que les deux seules fonctions de base à traduire sont :
ROUND : ARRONDI
POWER : PUISSANCE

A+
0