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 :

Imbriquer des Instructions with


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    retraite
    Inscrit en
    Avril 2010
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : Espagne

    Informations professionnelles :
    Activité : retraite
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2010
    Messages : 325
    Par défaut Imbriquer des Instructions with
    bonsoir
    j'ai une fonction ci dessous


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    With Sheets("Janv")
        For i = 9 To 73
            .Range("B" & i) = 0
    est il possible de mettre plusieurs feuilles avec la fonction with

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    with sheets("Janv").("Fevr")
    mais je connais pas la syntaxe
    si quelqu'un la connais.
    merci

  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 174
    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 174
    Billets dans le blog
    53
    Par défaut
    Bonsoir,
    Je n'ai pas réussis à faire mieux
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     Sheets(Array("Feuil1", "Feuil2", "Feuil3")).Select
     With Sheets("Feuil1")
      For i = 9 To 73
      .Range("B" & i) = 0
      Next i
     End With
     Sheets("Feuil1").Select
    ou bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     Sheets(Array("Feuil1", "Feuil2", "Feuil3")).Select
     With Sheets("Feuil1")
      .Range("B9:B73") = 0
     End With
     Sheets("Feuil1").Select
    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 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
    With n'est pas une fonction mais une instruction de bloc permettant d'éviter la répétition fastidieuse d'un nom d'objet dans le code.

    Et non, on ne peut pas imbriquer les blocs With les uns dans les autres.

    Place le curseur sur le mot et tape F1 pour afficher la rubrique d'aide sur ce sujet.

  4. #4
    Membre Expert Avatar de Godzestla
    Homme Profil pro
    Chercheur de bonheur
    Inscrit en
    Août 2007
    Messages
    2 403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chercheur de bonheur
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 2 403
    Par défaut
    Et non, on ne peut pas imbriquer les blocs With les uns dans les autres.
    Si, on peut. Je le fais souvent.

  5. #5
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Par défaut
    Bonjour,

    Et en bouclant sur tes feuilles ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Dim Fe As Worksheet
    'ne pas écrire Sheets, si il y a une feuille graphique > erreur !!!
    For Each Fe In Worksheets
        Fe.[B9:B73] = 0
    Next Fe
    Bonne journée.
    Hervé.

  6. #6
    Membre Expert Avatar de Godzestla
    Homme Profil pro
    Chercheur de bonheur
    Inscrit en
    Août 2007
    Messages
    2 403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chercheur de bonheur
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 2 403
    Par défaut
    'ne pas écrire Sheets, si il y a une feuille graphique > erreur !!!
    merci pour l'info Hervé, j'ignorais cette nuance bien intéressante.

  7. #7
    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
    Citation Envoyé par Godzestla Voir le message
    Si, on peut. Je le fais souvent.
    T'as quelle version de Office ?

    Je voudrais bien voir ça. Comment le compilateur (ou interpréteur, dans ce cas-ci) peut démêler pour lequel des objets imbriqués dans des blocs With successifs '.laMéthode' est appelée?

    [Edit]
    Je me rétracte, sous réserve...
    L'aide de VBA dit ceci
    Vous pouvez imbriquer des instructions With en plaçant un bloc With à l'intérieur d'un autre. Toutefois, les membres des blocs With externes étant masqués dans les blocs With internes, vous devez fournir dans les blocs internes une référence complète pour tous les membres d'un objet figurant dans un bloc externe.
    La petite réserve...
    J'imagine que pour garder le code lisible, ce n'est pas toujours utile d'imbriquer tant de blocs With. Mais ça reste mon opinion. (Ça doit être mon orgueil qui parle...)

  8. #8
    Membre Expert Avatar de Godzestla
    Homme Profil pro
    Chercheur de bonheur
    Inscrit en
    Août 2007
    Messages
    2 403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chercheur de bonheur
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 2 403
    Par défaut
    Envoyé par Zazaraignée : Ça doit être mon orgueil qui parle..
    Pas mal ta réponse, tu es la seule à savoir si elle est pertinente.

    je partage ton avis sur le risque d'illisibilité du code du code.

    C'est à utiliser avec parcimonie et dicernement, qualités typiquement féminines non ?

    Un exemple simpliste d'utillisation propre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    With Workbooks("Le classeur.xls"
     '.... ici du code sur l'object Workbook
     
         With .Sheets("La feuille")
     '      ici du code sur la feuille
     
            With .Range(My_range)
    '   ici du code sur le range
     
            End With
        End With
    End With

Discussions similaires

  1. Question sur instruction With imbriquée
    Par LadyWasky dans le forum Bases de données
    Réponses: 2
    Dernier message: 14/10/2005, 11h26
  2. Imbriquer des logic:iterate
    Par lalou33 dans le forum Struts 1
    Réponses: 4
    Dernier message: 16/06/2004, 10h31
  3. Réponses: 12
    Dernier message: 18/03/2004, 15h09
  4. Temps d'exécution des instructions FPU
    Par ubi dans le forum Assembleur
    Réponses: 2
    Dernier message: 24/10/2003, 18h39
  5. Mesurer le temps des instructions
    Par luckylucke dans le forum Assembleur
    Réponses: 9
    Dernier message: 03/09/2003, 21h23

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