Comment désigner une feuille excel par son codename
Résolu
wire less
Messages postés
233
Date d'inscription
Statut
Membre
Dernière intervention
-
wire less Messages postés 233 Date d'inscription Statut Membre Dernière intervention -
wire less Messages postés 233 Date d'inscription Statut Membre Dernière intervention -
A voir également:
- Excel vba activer une feuille par son nom
- Feuille de score belote excel - Forum Excel
- Liste déroulante excel - Guide
- Feuille de pointage excel - Télécharger - Tableur
- Excel trier par ordre croissant chiffre - Guide
- Déplacer une colonne excel - Guide
5 réponses
Bonjour,
Toujours avec le code Name!
Toujours avec le code Name!
Option Explicit Private Sub CommandButton1_Click() Dim wsh As Worksheet Workbooks.Open ("C:\Users\.....\Documents\Classeur2.xlsx") 'boucle sur toutes les feuilles For Each wsh In ActiveWorkbook.Worksheets ' pour chaque feuille du classeur MsgBox wsh.Name Next 'on passe à la feuille suivante 'feuille active MsgBox ActiveSheet.Name End Sub
Mais il s'agit bien d'une confusion ... et j'essai justement de la résoudre.
Si je reprend ton script et que je le complète avec ce dont j'ai besoin :
Alors tu te rendra compte que chaque feuille possède un "Name" : c'est le nom de l'onglet écris sur l'onglet Excel, et un CodeName. Le CodeName c'est le vrai nom de l'objet feuille.
J'ai besoin du CodeName parce qu'il est écris en dur et que l'utilisateur ne peut pas le modifier simplement en cliquant-droit sur l'onglet et en le renommant. Ainsi, pas de possibilité d'erreur pour mon script.
Malheureusement, il est facile d'appeler un CodeName sur l'instance d'excel à l'origine de la macro ... (Feuil1.Select ou lieu de Sheets("Nom_de_Mon_Onglet").Select
Mais lorsqu'il s'agit d'une autre feuille Excel ... ben c'est plus la même chose !!
Si je fait :
ça marche.
J'ai une erreur :
Erreur d'exécution '1004':
La méthode 'Select' de l'objet '_Workshhet' a échoué
...
Quelqu'un aurait une idée ??
MsgBox wsh.CodeName
Il me semble que c'est moi qui l'ai écris ... toi tu n'as fait référence qu'à
MsgBox wsh.Name
Mon problème reste le même.
Dans ma feuille je ne connais que mon "CodeName" ... et pas mon "Name".
Le "CodeName" en question c'est "Feuil1". Si je veux connaitre le "Name" associé je n'ai qu'à faire :
MsgBox Feuil1.Name
Je reviens à mon problème :
ça marche
ça marche pas.
ou encore :
qui ne marche pas non plus.
Je précise que ces méthodes marchent très bien quand je travail que sur les feuilles de l'excel qui exécute la macro.
J'aurais aimé faire un par exemple ...
mais sa ne marche pas non plus ...
J'ai plus d'idée !
Merci encore tout le monde !!