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 :

Macro pour aficher et masqué des onglets


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2011
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2011
    Messages : 52
    Par défaut Macro pour aficher et masqué des onglets
    Bonsoir,
    J'ai des flèches gauche et droite aux quelles je souhaite attribuer une macro
    Quand je clique sur la flèche de gauche je souhaite faire apparaitre les feuilles "test1 & test2) et disparaitre (test3 & test4) et quand je clique sur celle de droite je souhaite faire apparaitre les feuilles "test3" & "test4") et disparaitre ("test1" & test2")

    Quelle partie de la macro je dois modifier
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub 1()
    Sheets("Test1").Visible = True
    Sheets("Test2").Visible = True
    Sheets("Test3").Visible = False
    Sheets("Test4").Visible = False

  2. #2
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

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

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Je ne sais pas quelles flêches tu as prises mais, essayes ça
    avec un click droit et "Affecter une macro"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub Flèchedroite1_Clic()
    Sheets("Test1").Visible = False
    Sheets("Test2").Visible = False
    Sheets("Test3").Visible = True
    Sheets("Test4").Visible = True
     
    End Sub
    Sub Flèchegauche2_Clic()
    Sheets("Test1").Visible = True
    Sheets("Test2").Visible = True
    Sheets("Test3").Visible = False
    Sheets("Test4").Visible = False
     
    End Sub
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2011
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2011
    Messages : 52
    Par défaut
    J'avais déjà essayer ça mais ça ne fonctionne pas, je crois que c'est le fait d'afficher et masque 2 feuilles qui pose problème dans le code.

    Il devrait y avoir un séparateur ou un and genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub Janvier()
    Sheets("Test1") and ("Test2").Visible = False
    Sheets("Test3") and ("Test4") .Visible = True
    End Sub
    Mais ça fonctionne pas non plus

    Pour une feuille ça fonctionne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub 1()
    Sheets("Test2").Visible = False
    Sheets("Test1").Visible = True
    End sub
    Mais pas moyen pour 2 feuilles

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2011
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2011
    Messages : 52
    Par défaut
    Je progresse j'arrive maintenant a masqué 2 feuilles mais pas a afficher les 2 autres

    Pour masquer 2 feuilles:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub 1()
    Sheets(Array("Test1", "Test2")).Visible = False
    End Sub

  5. #5
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

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

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    J'ai fait comme je t'ai préconisé et ça fonctionne, regardes le fichier
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  6. #6
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    Pourquoi vouloir passer par un Array ?

    Comme déjà dit, ceci fonctionne très bien.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub Gauche()
        Sheets("Feuil1").Visible = xlSheetVisible
        Sheets("Feuil2").Visible = xlSheetVisible
        Sheets("Feuil3").Visible = xlSheetHidden
        Sheets("Feuil4").Visible = xlSheetHidden
    End Sub
     
    Sub Droite()
        Sheets("Feuil1").Visible = xlSheetHidden
        Sheets("Feuil2").Visible = xlSheetHidden
        Sheets("Feuil3").Visible = xlSheetVisible
        Sheets("Feuil4").Visible = xlSheetVisible
    End Sub
    Si ça ne fonctionne pas, est-ce que tu reçois un message d'erreur ?

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2011
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2011
    Messages : 52
    Par défaut
    ok cela fonctionne, mais c'est possible qu'en plus d'afficher la feuille il l'ouvre?
    donc on affiche "feuille1" mais on ce positionne aussi dessus

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

Discussions similaires

  1. [XL-2013] Macro pour aficher et masqué des onglets
    Par d.deneys dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 26/08/2013, 09h30
  2. [XL-2007] MACRO pour compter le nombre des fichiers sur le serveur FTP
    Par kinkichin dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 04/07/2011, 18h09
  3. macro pour lister le nom des étudiants selon une catégorie
    Par stefany83 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 30/07/2010, 12h18
  4. macro pour automatiser l'évaluation des garch
    Par paiva44 dans le forum Macro
    Réponses: 2
    Dernier message: 22/01/2010, 22h11
  5. [XL-2003] macro pour afficher les dates des troisièmes vendredi du mois
    Par julius999 dans le forum Macros et VBA Excel
    Réponses: 21
    Dernier message: 28/10/2009, 17h39

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