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 :

Une boucle qui me rend chevre [XL-2016]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Homme Profil pro
    amateur
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : amateur
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Par défaut Une boucle qui me rend chevre
    Bonjour
    je suis débutant avec VBA sur excel
    je fais un userform
    dans Private Sub UserForm_Initialize()
    je dois clacul une variable qui doit etre egale à:
    8,10,12,15 ou20
    donc j'ai creer deux variable
    la première Np est le resultat réel de l'equation et en fonction de ce résultat je trouve MA variable à afficher que j'ai appelé Npp.
    exemple: je calcul je trouve Np=6,532 donc Npp=8
    Np= 10,532 donc Npp=12

    j'ai penser à faire une boucle do until
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Dim Np As Single, Su As Long, Spi As Long, Ele As Variant, Npp As Single
    'les variable de calcul se trrouvant dans un tableau excel
    Su = Sheets("Projet 1").Range("B10")
    Ele = Sheets("Projet 1").Range("B9")
    Spi = Sheets("Projet 1").Range("B8")
    Np = ((3 * Su) / (Spi * NL * LL)) 'le résultat réel de l'équation
    Do Until Npp = 8 Or Npp = 10
    Npp = Int(Np) + 1 'la valeur que je veux afficher 8 10 12 15 ou 20
    Exit Do
    Loop
     
    TextBox9 = Npp
    Le problème c'est que la boucle s'arrete au premier plus 1
    exemple : pour Np=6,532 Npp=7 au lieu de 8

    Merci pour votre aide

  2. #2
    Membre Expert
    Inscrit en
    Septembre 2007
    Messages
    1 142
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 142
    Par défaut
    Bonjour

    Citation Envoyé par foxgarde Voir le message
    j'ai penser à faire une boucle do until
    Tu remplaces ta boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Do Until Npp = 8 Or Npp = 10
    Npp = Int(Np) + 1 'la valeur que je veux afficher 8 10 12 15 ou 20
    Exit Do
    Loop
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Npp = Application.Choose(Application.Match(Np, Array(0, 8, 10, 12, 15, 20), 1), 8, 10, 12, 15, 20)

  3. #3
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 682
    Par défaut
    Salut,

    sans parler de ton énoncée quelque peu bancal, je me contente de travailler sur la boucle en elle même, en gardant ici une syntaxe approximative pour coller a ton code d'origine :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Npp=Int(Np)
    Do Until Npp = 8 Or Npp = 10 Or Npp = 12 or Or Npp = 15 or Or Npp = 20
    Npp = Int(Npp) + 1 'la valeur que je veux afficher 8 10 12 15 ou 20
    Exit Do
    Loop
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Migrer les applications VBA Access et VBA Excel vers la Power Platform
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Coffrets disponibles de mes ouvrages : https://www.editions-eni.fr/jean-philippe-andre
    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  4. #4
    Membre régulier
    Homme Profil pro
    amateur
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : amateur
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Par défaut
    SALUT
    merci a vous deux pour ces réponses
    anasecu ça marche nickel
    mais Jean-Philippe André sur ta deuxième ligne j'ai une erreur de syntaxe. si je devait la corrigé comme je peu faire
    et encore une fois merciiiiiiiiiiiiii

  5. #5
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 682
    Par défaut
    Une erreur de copier/coller :o
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Do Until Npp = 8 Or Npp = 10 Or Npp = 12 Or Npp = 15 Or Npp = 20
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Migrer les applications VBA Access et VBA Excel vers la Power Platform
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Coffrets disponibles de mes ouvrages : https://www.editions-eni.fr/jean-philippe-andre
    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  6. #6
    Membre régulier
    Homme Profil pro
    amateur
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : amateur
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Par défaut
    Pardon si j'abuse de votre gentillesse

    comment peu-ton simplifier un IF avec plusieurs condition IF OR OR... il suffit d'une vrai pour faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    If Ele = A Or Ele = A2 Or Ele = ASM Or Ele = B1 Or Ele = B2 Or Ele = B3 Or Ele = C Or Ele = D Or Ele = E Or Ele = F Or Ele = G2 Or Ele = H Or Ele = H2 Or Ele = HSM Then
     
    Npp = Application.Choose(Application.Match(Np, Array(0, 8, 10, 12, 15, 20), 1), 8, 10, 12, 15, 20)
    Else
     If Ele = j Or Ele = K Then
     Npp = Npp = Application.Choose(Application.Match(Np, Array(0, 3, 4, 5), 1), 3, 4, 5)
    End If
    End If
    merci

  7. #7
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour
    Intéresse-toi à l'instruction Select Case -->> rubrique Select Case, instruction de ton aide interne VBA

    Tu devrais saisir cette occasion pour lire une très récente discussion :
    https://www.developpez.net/forums/d1...d/#post9801987

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 06/04/2007, 13h31
  2. Réponses: 10
    Dernier message: 07/01/2007, 12h03
  3. [Tableaux] une boucle qui ne boucle pas
    Par taly dans le forum Langage
    Réponses: 9
    Dernier message: 19/09/2006, 17h25
  4. [Débutant] une boucle for me rend fou.
    Par SirDarken dans le forum Langage
    Réponses: 6
    Dernier message: 12/09/2006, 23h25
  5. [VBA-E]une boucle qui ne s'arrète pas
    Par vivelesgnous dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 15/02/2006, 18h05

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