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 :

[VBA] [Excel] feuille masquée = pas de macro?


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 36
    Par défaut [VBA] [Excel] feuille masquée = pas de macro?
    Bonjour à tous!

    Voilà, j'ai masqué une feuille dans un classeur pour éviter qu'elle ne soit supprimée par inadvertance.

    Cependant, j'ai une macro dans un autre classeur qui fait appel à cette feuille. Mais comme elle est masquée, j'ai un message d'erreur indiquant : "erreur d'exécution 1004 : la méthode Select de la classe Worksheet a échoué."

    Comment remédier à ce problème?

    Merci d'avance!

  2. #2
    Membre Expert Avatar de Megaxel
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    1 187
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 1 187
    Par défaut
    Salut!
    Est-ce que tu es obligé de faire des SELECT sur cette feuille? On peut souvent s'en passer.
    Sinon, rend ta feuille visible au début de ta macro, puis recache la à la fin (Propriété ".Visible" de WorkSheets("MaFeuilleCachée")

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 36
    Par défaut
    oui je suis obligée de faire des Select dans cette feuille.
    Je vais essayé ce que tu me proposes.
    Merci!

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Bonjour

    Il est normal que tu ne puisses pas sélectionner une feuille invisible. Comment VBA pourrait-il donner le focus à une cellule d'une feuille s'il ne peut afficher celle-ci? :

    Toutefois, et pour rappel, il n'est pas nécessaire de sélectionner une feuille pour pouvoir travailler avec.

    Tu peux très bien manipuler les cellules d'une feuille masquée en faisant référence à celle-ci, comme dans le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
        Dim Feuille As Worksheet
     
        Set Feuille = Worksheets("Données")
        Feuille.Range("a1") = "Pierre"
    Note toutefois qu'en utilisant le nom Excel de la feuille, tu t'exposes à une erreur d'exécution si ta feuille est renommée par l'utilisateur. Tu as tout intérêt à utiliser le nom VBA de la feuille, que tu trouves ou modifies via la fenêtre de propriétés de la feuille, dans VBE. Moi, je nomme mes feuilles (nom VBA) en les faisant précéder du préfixe sh_ (sheet en anglais...). Dès lors, si ma feuille Données (nom excel) est nommée en vba sh_Donnees, le code devient alors
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
        Dim Feuille As Worksheet
     
        Set Feuille = sh_donnees
        Feuille.Range("a1") = "Pierre"
    Ok?

    Pierre Fauconnier
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  5. #5
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Par défaut
    D'après moi, on n'est jamais obligé de faire des Select.

    Il y a plein d'autres options pour travailler dans une feuille.

    Peux-tu nous dire pourquoi tu dois faire des Select?

    Edit--> Grillé par Pierre Fauconnier
    N'oubliez pas de cliquer sur quand vous avez obtenu ou trouvé vous-même la réponse à votre question.
    Si vous trouvez seul, pensez à poster votre solution. Elle peut servir à d'autres!
    Pensez aussi à voter pour les réponses qui vous ont aidés.
    ------------
    Je dois beaucoup de mes connaissances à mes erreurs!

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Pourquoi es-tu obligée d'effectuer des SELECT dans cette feuille? Si tu la manipules par VBA, SELECT (qui "imite" la manipulation de la feuille par l'utilisateur) est souvent inutile et ralentit considérablement la macro. Il y a souvent moyen de contourner le SELECT en utilisant des objets Worksheet, Range et Cells...

    Ok?

    Pierre Fauconnier

    Et moi, grillé par toi, Alain, et par Megaxel
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 36
    Par défaut
    Je fais des Select dans cette feuille car elle me sert de base pour des copier/coller dans une compilation. Et je ne peux pas utiliser Range ou Cells car il y a une boucle de recherche des lignes vides, etc (ce serait trop long à expliquer).
    Voici donc la petite modification que j'ai faite dans le code de ma macro, au début.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Sheets("Données").Visible = True
        Sheets("Données").Select
    Ma compilation s'est très bien faite! Et je n'ai pas eu à écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("Données").Visible = False
    à la fin car en fait, à la fin du code d'une des macros, j'ai mis:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Workbooks("Heures D-Dupont.XLS").Close SaveChanges:=False
    Enfin, le principal c'est que ça fonctionne, et qu'il est possible de travailler sur une feuille masquée.
    Merci!
    Le problème est résolu pour ma part mais bon, le post a semble-t-il faitréagir certains....

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

Discussions similaires

  1. [XL-2003] VBA Excel/Access: lecture seule après macro
    Par lahila dans le forum Macros et VBA Excel
    Réponses: 22
    Dernier message: 30/09/2011, 12h44
  2. [VBA-Excel] Ne comprends pas le message d'erreur
    Par marsupilami34 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 03/05/2011, 16h49
  3. [VBA-Excel] Feuille Excel vers Form VB
    Par serbrech dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 11/05/2007, 22h07
  4. [VBA EXCEL] password mis dans la macro
    Par ecirb dans le forum VBA Word
    Réponses: 10
    Dernier message: 28/02/2007, 18h32
  5. Réponses: 7
    Dernier message: 19/07/2005, 08h31

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