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 :

Utiliser une macro conditionnée au nom de la feuille


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2023
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2023
    Messages : 11
    Par défaut Utiliser une macro conditionnée au nom de la feuille
    Re bonjour,
    Je souhaite appliquer une macro à toutes les feuilles qui contiennent la chaine de caractère "DASHBOARD". J'ai rédigé le code ci-dessous, mais il ne compile pas. J'ai défini une autre variable, fcalc, car je dois aller récupérer une valeur (constante) qui est présente dans toutes les feuilles ayant le nom "Calculations*", en cellule D17. Je ne sais pas vraiment où est le problème.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    Sub Calc()
        Dim ws As Worksheet
        Dim fcalc As Worksheet
        Dim a As String
     
        For Each fcalc In ThisWorkbook.Worksheets
            If fcalc.Name Like "Calculations*" Then
                a = fcalc.Name
            End If
        Next
     
        For Each ws In ThisWorkbook.Worksheets
     
            If ws.Name Like "DASHBOARD*" Then
                ThisWorkbook.Sheets(ws.Name).Range("$O$26") = ThisWorkbook.Sheets(ws.Name).Range("$O$41") / ThisWorkbook.Sheets(a).Range("$D$17") * 1000000
            End If
     
        Next
     
    End Sub
    Merci pour vos avis éclairés!

  2. #2
    Membre émérite
    Homme Profil pro
    Retraité
    Inscrit en
    Octobre 2022
    Messages
    685
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Octobre 2022
    Messages : 685
    Par défaut
    Bonjour,

    déjà la première boucle : tu récupères dans a le nom de la dernière feuille qui commence par "calculations"
    je ne comprends pas pourquoi aller chercher le nom de la dernière feuille qui commence par "calculations" (mais ça ce n'est pas trop grave )

    ensuite

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ThisWorkbook.Sheets(ws.Name).Range
    pourra être remplacé avantageusement par

    comme tu l'as fait pour fcalc, d'ailleurs.

    Ensuite quel est le problème ? Il se passe quoi en O26 dans les feuilles DASHBOARD* ?

    Si tu as l'impression qu'il ne se passe rien commence par remplacer la ligne par un truc plus simple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ws.Range("$O$26") = "Etabli was here"
    histoire de voir déjà si tu passes bien dans la feuille, puis complexifie progressivement pour trouver ce qui coince .

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2023
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2023
    Messages : 11
    Par défaut
    Bonjour,

    Le code fonctionne finalement mais tes remarques appellent des questions de mon côté:

    -> je récupère le nom de la dernière feuille qui contient "calculations" parce que toutes les feuilles calculations ont le même agencement de données, et cela me permet de récupérer la donnée en D17 qui est donc la même dans toutes ces feuilles. J'aurais pu la récupérer dans la première sur laquelle on tombe en parcourant le classeur, mais la boucle était plus simple pour moi. Si je veux récupérer D17 dans la 1ère feuille Calculations que je croise, j'utilise quelle syntaxe? Je définis une variable intermédiaire "b" et je fais quelque chose comme:

    When ThisWorkbook.Sheets.Name Like "Calculation*" then b = ActiveSheets.Range("D17")
    ?

    -> quand tu écris ws.range, ça signifie qu'en terme de syntaxe tu n'as pas besoin de conserver le "ThisWorkbook.Sheets(ws.Name).Range("026")" mais que cela donne simplement ws.Range("O26") ? Le compilateur comprend sans le suffixe?
    Merci

  4. #4
    Membre Expert
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    1 576
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 1 576
    Par défaut
    Citation Envoyé par Etabli Voir le message
    Bonjour,

    Le code fonctionne finalement mais tes remarques appellent des questions de mon côté:

    -> je récupère le nom de la dernière feuille qui contient "calculations" parce que toutes les feuilles calculations ont le même agencement de données, et cela me permet de récupérer la donnée en D17 qui est donc la même dans toutes ces feuilles. J'aurais pu la récupérer dans la première sur laquelle on tombe en parcourant le classeur, mais la boucle était plus simple pour moi. Si je veux récupérer D17 dans la 1ère feuille Calculations que je croise, j'utilise quelle syntaxe? Je définis une variable intermédiaire "b" et je fais quelque chose comme:

    When ThisWorkbook.Sheets.Name Like "Calculation*" then b = ActiveSheets.Range("D17")
    ?
    Il y a juste besoin de rajouter une ligne Exit For après la ligne 8 (sur laquelle on a récupéré notre feuille)

    -> quand tu écris ws.range, ça signifie qu'en terme de syntaxe tu n'as pas besoin de conserver le "ThisWorkbook.Sheets(ws.Name).Range("026")" mais que cela donne simplement ws.Range("O26") ? Le compilateur comprend sans le suffixe?
    Merci
    quel suffixe ? (quand c'est avant c'est un préfixe )
    tu récupères dans ws chacune des feuilles du classeur donc autant travailler directement avec cette variable.

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 25/02/2008, 11h40
  2. utiliser une macro partout
    Par mhamedbj dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 05/09/2007, 09h09
  3. Utiliser une macro Excel sous access
    Par Manu59410 dans le forum VBA Access
    Réponses: 6
    Dernier message: 28/08/2007, 09h08
  4. [VBA] utiliser une macro contenue dans un autre classeur
    Par laloune dans le forum Macros et VBA Excel
    Réponses: 20
    Dernier message: 01/02/2006, 18h46
  5. Macro utilisant une macro...
    Par Gogoye dans le forum C
    Réponses: 2
    Dernier message: 29/10/2003, 14h22

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