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 :

VBA Excel Arrondi


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Avril 2007
    Messages : 21
    Par défaut
    Bonjour,

    je souhaiterais connaître la commande VBA permettant de faire des arrondis inférieur à un chiffre après la virgule.

    Mici!

    J'aimerais aussi savoir comment chercher dans une colonne un chiffre spécifique
    exemple chercher (A1:A30;6)

  2. #2
    Membre Expert
    Avatar de zazaraignée
    Profil pro
    Étudiant
    Inscrit en
    Février 2004
    Messages
    3 174
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2004
    Messages : 3 174
    Par défaut
    Arrondi --> fonctionv VB --> Round. Pour connaître la syntaxe exacte --> F1

    Formule de cellule RechercheV et F1. Enregistrement de macro avec cette formule peut révéler la syntaxe en VBA.

  3. #3
    Membre émérite
    Inscrit en
    Avril 2007
    Messages
    667
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Avril 2007
    Messages : 667
    Par défaut
    A noter que round arrondi au plus pres, pas a l'inferieur. Si tu as vraiment besoin d'arrondir a l'inferieur il ne me semble pas qu'il y ait de fonction VBA mais il est possible d'en creer une (En tronquant si l'arrondi est plus grand que le nombre original).

    Pour ta recherche, fait une recherche sur le forum Rien que le mot clef For en choisissant uniquement le forum VBA Excel devrait te donner la reponse.

  4. #4
    Membre émérite
    Homme Profil pro
    retraité
    Inscrit en
    Mai 2006
    Messages
    542
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Mai 2006
    Messages : 542
    Par défaut
    Bonjour àtous

    Essaie ceci

    arrondi_inf = WorksheetFunction.RoundDown(Range("e17"), 1)
    "e17" étant la cellule à arrondir inf

    Eric

  5. #5
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419

  6. #6
    Membre émérite
    Homme Profil pro
    retraité
    Inscrit en
    Mai 2006
    Messages
    542
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Mai 2006
    Messages : 542
    Par défaut
    Re

    en fonction, il y a aussi :

    Eric

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Avril 2007
    Messages : 21
    Par défaut Merci à tous
    Merci pour vos réponses ca m'a bcp aidé.

    A bientôt.

  8. #8
    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
    Si ton problème est résolu, un petit clic sur le bouton du même nom, sous la discussion?

    Merci
    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!

  9. #9
    Membre confirmé
    Inscrit en
    Janvier 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 129
    Par défaut
    Ca renvoie 0...
    Au plus pres, il me semble que ca devrait renvoyer 1 ou bien je me pose de serieux doutes quant a mes souvenirs d'ecole primaire...
    Non?

    Edit: Et la meme formule dans Excel renvoie bien 1...

  10. #10
    Expert confirmé

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Par défaut
    bonjour

    Round(0.5, 0)Ca renvoie 0...
    Au plus pres, il me semble que ca devrait renvoyer 1 ou bien je me pose de serieux doutes quant a mes souvenirs d'ecole primaire...
    Non?

    Edit: Et la meme formule dans Excel renvoie bien 1...
    c'est normal car la fonction VBA Round n'eest pas identique à la fonction de la feuille de calcul:
    http://support.microsoft.com/default...b;en-us;225330


    bon week end
    michel

  11. #11
    Membre confirmé
    Inscrit en
    Janvier 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 129
    Par défaut
    The expression contains an even numbered integer ending in the decimal .5.
    Tu as raison, merci bien...
    Incomprehensible pour ma logique, mais on va faire avec.
    Merci!

  12. #12
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Par défaut
    Citation Envoyé par Lameth Voir le message
    Tu as raison, merci bien...
    Incomprehensible pour ma logique, mais on va faire avec.
    Merci!
    Et tu as bien raison d'en faire la remarque, Lameth...

    J'ai il y a quelque temps cherché à comprendre le pourquoi de la chose ...

    Ma conclusion ? un poil dans la main d'un développeur à Chicago ...

    Il a à mon avis joué au malin pour faire "plus court" et ... voilà le type de résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub Command1_Click()
      titi = Array(5.1, 4.2, 4.4, 5.5, 4.5, 5.6)
      For i = 0 To UBound(titi)
        Dim toto As Single
        toto = titi(i)
        MsgBox titi(i) & " =====>>" & Int(toto) + (toto Mod Int(toto))
      Next
    End Sub
    Lance et observe bien ==>> tu verras que tout va bien sauf lorsque ... la partie entière est paire et que la partie décimale est = 5

    Pile poil son bug (le coquin, va ...)

    Commentaires ?

  13. #13
    Membre confirmé
    Inscrit en
    Janvier 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 129
    Par défaut
    Pas mal...

    En effet, j'ai a plusieurs reprise remarquer ce bug sans pour autant le comprendre (paire / impaire) du coup ca oblige a faire des hypotheses pour debusquer et contourber les bugs.

  14. #14
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Par défaut
    The very big problem, maintenant, pour l'équipe de Bill ?

    Comment corriger ce bug (car c'en est un) sans compromettre les applications déjà développées et distribuées ? ===>> pas possible !!!

    Que fait-il alors ? ===>> invite à passer par Excel au lieu de VBA ... (elle est bien bonne !!)

  15. #15
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Par défaut
    J'ai voulu faire cette nuit une petite fonction d'arrondi au nombre le plus proche.

    La voilà :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Function arrondissons(nb As Double, precis As Integer) As Double
        Dim t1 As Single, t2 As Long
        t1 = Abs(nb * (10 ^ precis))
        t2 = Fix(t1)
        arrondissons = ((t2 - ((t1 - t2) >= 0.5)) / (10 ^ precis)) * Sgn(nb)
    End Function

    - nb est le nombre à traiter (en numérique et avec le . comme séparateur de décimales)
    - precis est le nombre de décimales après arrondissement

    Cette fonction arrondit également les nombres négatifs
    Ele est par contre limitée en matière de grandeur du nombre traité

  16. #16
    Invité de passage
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1
    Par défaut
    J'avais trouvé la fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function MyRound2(Number As Double, iDigit As Integer) As Double
      MyRound2 = (Int((Number * (10 ^ iDigit)) + 0.5)) / (10 ^ iDigit)
    End Function
    Mais elle bug aussi alors que la même formule décomposée en plusieurs lignes ne bug pas .... faut-il encore dire merci à MS ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Public Function MyRound(Number As Double, iDigit As Integer) As Double
    ' Fonction écrite parce que la fonction Round de VBA est bugée.
      MyRound = Number * (10 ^ iDigit)
      MyRound = MyRound + 0.5
      MyRound = Int(MyRound)
      MyRound = MyRound / (10 ^ iDigit)
    End Function
    Quand je teste les fonctions avec Number = 0.335205 et iDigit = 5 j'ai
    MyRound2 = 0,33520
    MyRound = 0,33521

    Merci pour l'idée des fonctions Abs et Sign pour que cela fonctionne aussi avec les nombres négatifs, je vais les ajouté dans ma fonction.

Discussions similaires

  1. [VBA-Excel,VB6,Fichier texte]enregistrer un classeur excel..
    Par Tarul dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 11/01/2005, 13h09
  2. [vba-excel] Le temps de fermeture trop court ?
    Par Damsou dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 11/01/2005, 10h03
  3. [VBA-Excel]
    Par Damsou dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 05/01/2005, 10h17
  4. [VBA EXCEL] Réduire/Agrandir UserForms
    Par Fench dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 06/11/2003, 16h02
  5. [VBA Excel] Effacer rapidement une feuille
    Par Invité dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 24/10/2002, 13h12

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