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 :

Comment convertir formule pour VBA (Textbox et Userform)


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Décembre 2019
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Décembre 2019
    Messages : 2
    Par défaut Comment convertir formule pour VBA (Textbox et Userform)
    Je cherche à convertir une formule que j'ai sur une feuille Excel vers un Textbox dans un Userform.

    J'ai pu en convertir une simple, mais j'ai de la misère avec celle-ci avec des fomule impbriquée. Si quelqu'un peut m'aider.

    J'ai utlisé l'enregistrement macro afin de la convertir en VBA, mais je n'ai envie qu'elle soit indépdendante des cellules.

    Formule Excel :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SOMMEPROD((SOUS.TOTAL(3;INDIRECT("U"&LIGNE($U$13:$U$400)))*($U$13:$U$400="Oui") ))
    Formule Macro :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "=SUMPRODUCT((SUBTOTAL(3,INDIRECT(""U""&ROW(R13C21:R400C21)))*(R13C21:R400C21=""Oui"") ))"
    VBA pour textobox (que je cherche à faire et qui me donne que des messages d'erreur à chaque fois):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TextBox1 = WorksheetFunction.SumProduct(Sheets("Feuille1")((Subtotal(3, Indirect("U" & Rows("U3:U400"))) * Range("U3:U400"))), "Oui")

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 173
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Pourquoi ne pas utiliser tout simplement la fonction Evaluate ?
    Imaginons que le contrôle nommé TextBox1 fasse référence à la cellule E5 qui contient une formule, le code sera
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
      With Me
      .TextBox1.Value = Evaluate(Range("E5").Formula)
      End With
    Ceci n'est qu'un simple exemple, il y a lieu bien entendu de ne pas oublier de préciser la parentalité de l'objet Range (Classeur + Feuille)
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  3. #3
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 179
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    A tester, la feuille concernée devrait être activée pour une bonne évaluation

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    TextBox1.text=evaluate("SUMPRODUCT((SUBTOTAL(3,INDIRECT(""U""&ROW($U$13:$U$400)))*($U$13:$U$400=""Oui"")))")

  4. #4
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Décembre 2019
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Décembre 2019
    Messages : 2
    Par défaut
    Citation Envoyé par tototiti2008 Voir le message
    Bonjour,

    A tester, la feuille concernée devrait être activée pour une bonne évaluation

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    TextBox1.text=evaluate("SUMPRODUCT((SUBTOTAL(3,INDIRECT(""U""&ROW($U$13:$U$400)))*($U$13:$U$400=""Oui"")))")
    Merci, mais cela ne fonctionne pas. Cela me donne une erreur. "Erreur d'execution 13 : Incompatibilité de type". Je cherche vraiment que cela soit le Userform qui le calcul sans passer par une feuil. C'est pour cette raison que j'ai utilisé au début

    WorksheetFunction
    Citation Envoyé par Philippe Tulliez Voir le message
    Bonjour,
    Pourquoi ne pas utiliser tout simplement la fonction Evaluate ?
    Imaginons que le contrôle nommé TextBox1 fasse référence à la cellule E5 qui contient une formule, le code sera
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
      With Me
      .TextBox1.Value = Evaluate(Range("E5").Formula)
      End With
    Ceci n'est qu'un simple exemple, il y a lieu bien entendu de ne pas oublier de préciser la parentalité de l'objet Range (Classeur + Feuille)
    Je cherche à ce que le Userform soit indépendant des caulculs qui pourraient être fait sur une feuil. Je veux que cela soit le Userform qui le calcule.

  5. #5
    Membre Expert Avatar de Transitoire
    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Décembre 2017
    Messages
    733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Auditeur informatique

    Informations forums :
    Inscription : Décembre 2017
    Messages : 733
    Par défaut
    Bonjour, je ne comprend pas la logique qui veut faire un calcul sur un UserForm en doublon de celui d'une feuille.
    Par ailleurs, sauf erreur ou omission de ma part, un TextBox Comme son nom l'indique contient une information sous forme de texte. ce qui pose souvent des problèmes dans le cas de nombre ou date.
    De toute les manières, je pense que le TextBox ne pourra contenir sous forme de texte que le résultat d'un calcul passant par du code, qu'il soit interne au UF ou externe(module).
    Vous devriez expliciter mieux, ce que vous souhaitez faire exactement.
    Cordialement

  6. #6
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 173
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Peu-importe que tu utilises Evaluate ou WorksheetFunction. Les deux options sont envisageables.
    La fonction Evaluate dans ce cas précis me semblait la plus simple à mettre en place

    Je ne comprends pas la phrase ci-dessous
    J'ai utlisé l'enregistrement macro afin de la convertir en VBA, mais je n'ai envie qu'elle soit indépdendante des cellules.
    Est-ce que cela signifie que tu n'as pas envie que la formule soit indépendantes des cellules ou bien le contraire et qu'est ce que cela signifie exactement car la formule que tu as publiée fait référence aux cellules.

    Pour info :
    Dans le code ci-dessous et que tu as publié, l'erreur qui est renvoyée provient du fait que seul SumProduct est rattaché à WorksheetFunction donc SubTotal, Indirect, etc. ne sont pas compris par le VBA
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TextBox1 = WorksheetFunction.SumProduct(Sheets("Feuille1")((Subtotal(3, Indirect("U" & Rows("U3:U400"))) * Range("U3:U400"))), "Oui")
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  7. #7
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 179
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    Il semblerait que Evaluate ait des soucis avec la fonction Indirect

    Peux-tu confirmer que la formule
    Code formule : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    =SOMMEPROD((SOUS.TOTAL(3;DECALER($U$13:$U$400;LIGNE($U$13:$U$400)-13;0;1;1))*($U$13:$U$400="Oui")))

    donne les mêmes résultats que l'originale

    Code formule : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    =SOMMEPROD((SOUS.TOTAL(3;INDIRECT("U"&LIGNE($U$13:$U$400)))*($U$13:$U$400="Oui")))

    ?

    Si oui, alors teste

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TextBox1.Text = Evaluate("SUMPRODUCT((SUBTOTAL(3,OFFSET($U$13:$U$400,ROW($U$13:$U$400)-13,0,1,1))*($U$13:$U$400=""Oui"")))")

Discussions similaires

  1. [AC-2013] Comment convertir une procédure VBA Access en macro ?
    Par morobaboumar dans le forum Access
    Réponses: 7
    Dernier message: 15/02/2019, 19h24
  2. [XL-2010] VBA : Rentrer une formule dans une textbox pour avoir un résultat numérique
    Par aurelu dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 21/06/2017, 22h28
  3. Convertir formule en VBA
    Par Floflo3163 dans le forum Excel
    Réponses: 1
    Dernier message: 09/07/2012, 15h13
  4. [VBA-E]Comment envoyer en parametre un textbox d'une userform
    Par EvaristeGaloisBis dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 22/09/2007, 14h16
  5. Réponses: 2
    Dernier message: 22/05/2006, 14h04

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