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 à l'essai
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    36
    Points
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 36
    Points : 23
    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 expérimenté Avatar de Megaxel
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    1 187
    Points
    1 405
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 1 187
    Points : 1 405
    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 à l'essai
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    36
    Points
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 36
    Points : 23
    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 129
    Points
    55 945
    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 129
    Points : 55 945
    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

  5. #5
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Points
    24 333
    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
    Points : 24 333
    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

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 129
    Points
    55 945
    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 129
    Points : 55 945
    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

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    36
    Points
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 36
    Points : 23
    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, 13h44
  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, 17h49
  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, 23h07
  4. [VBA EXCEL] password mis dans la macro
    Par ecirb dans le forum VBA Word
    Réponses: 10
    Dernier message: 28/02/2007, 19h32
  5. Réponses: 7
    Dernier message: 19/07/2005, 09h31

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