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 :

Affectation de feuille à une variable worksheet [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Avril 2011
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Avril 2011
    Messages : 62
    Par défaut Affectation de feuille à une variable worksheet
    Bonjour à toutes et à tous
    voilà je rencontre un petit problème en ce moment dans mon code
    j'ai ce programme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
        Dim a As String
        Dim feuilleMoisN_1 As Worksheet
        a = Worksheets(1).Range("A1").Value
        Set feuilleMoisN_1 = Worksheets(a)
    qui me permet d'affecter à feuilleMoisN_1 la feuille qui porte le nom de la variable a
    mais, lorsque je veux simplifier mon code en notant ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
        Dim feuilleMoisN_1 As Worksheet
        Set feuilleMoisN_1 = Worksheets(Worksheets(1).Range("A1").Value)
    j'ai une erreur d'exécution 9, "l'indice n'appartient pas à la sélection"
    est-ce que quelqu'un pourai m'aider svp?

  2. #2
    Invité
    Invité(e)
    Par défaut
    Salut,

    Il ne devrait pas y avoir de problème.

    Que contient la cellule:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Worksheets(1).Range("A1").Value

  3. #3
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set feuilleMoisN_1 = Worksheets(Cstr(Worksheets(1).Range("A1").Value))

  4. #4
    Invité
    Invité(e)
    Par défaut Bonjour,
    le message d'erreur n'est pas ambigu, soit A1=nul ou ne correspond pas au nom d'une feuille.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub test()
     Dim S As Integer
     For S = 1 To Worksheets.Count
     If Worksheets(S).Name = Worksheets(1).Range("A1").Value Then
       Set feuilleMoisN_1 = Worksheets(Worksheets(1).Range("A1").Value)
       exit for
    end if
     Next
    End Sub

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2011
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Avril 2011
    Messages : 62
    Par défaut
    en fait avec la solution de mercatog, je viens de comprendre mon problème
    la cellule contenait une série de chiffres (201309) qui correspondait au nom de la feuille que je cherchait à affecter à ma variable worksheet. Donc excel comprenait mon code comme étant la 201 309ème feuille et non pas la feuille dont le nom est "201309"
    du coup avec Cstr, ça fonctionne mieux

    merci beaucoup

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 31/10/2007, 15h40
  2. Réponses: 1
    Dernier message: 15/09/2007, 17h50
  3. Affecter et récupérer une variable de session
    Par vhellers dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 21/08/2007, 17h57
  4. Affecter et récupérer une variable de session
    Par vhellers dans le forum MS SQL Server
    Réponses: 0
    Dernier message: 16/08/2007, 15h15
  5. [DAO]Affecté résultat requête à une variable
    Par Lex O'Mil dans le forum VBA Access
    Réponses: 4
    Dernier message: 30/03/2007, 15h56

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