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 :

Workbook_open et ComboBox


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2008
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 66
    Par défaut Workbook_open et ComboBox
    Bonjour tout le monde,

    J'ai un léger problème.

    Afin que mes combobox soient prêts Quand j'ouvre le fichier, j'utilise le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    Private Sub Workbook_Open()
     
    ComboBox1.AddItem Worksheets("Feuil3").Range("A1")
    ComboBox1.AddItem Worksheets("Feuil3").Range("A2")
     
    Cable.AddItem Worksheets("Feuil3").Range("C1")
    Cable.AddItem Worksheets("Feuil3").Range("C2")
    Cable.AddItem Worksheets("Feuil3").Range("C3")
     
    rupteur.AddItem Worksheets("Feuil3").Range("A7")
    rupteur.AddItem Worksheets("Feuil3").Range("A8")
     
    ComboBox2.AddItem Worksheets("Feuil3").Range("A4")
    ComboBox2.AddItem Worksheets("Feuil3").Range("A5")
     
    pose.AddItem Worksheets("Feuil3").Range("F1")
    pose.AddItem Worksheets("Feuil3").Range("F2")
    pose.AddItem Worksheets("Feuil3").Range("F3")
    pose.AddItem Worksheets("Feuil3").Range("F4")
    pose.AddItem Worksheets("Feuil3").Range("F5")
     
    Naturesol.AddItem Worksheets("Feuil2").Range("J31")
    Naturesol.AddItem Worksheets("Feuil2").Range("J32")
    Naturesol.AddItem Worksheets("Feuil2").Range("J33")
    Naturesol.AddItem Worksheets("Feuil2").Range("J34")
    Naturesol.AddItem Worksheets("Feuil2").Range("J35")
     
    End Sub

    Mais ce code n'a pas l'air de fonctionner, il affiche "Objet requis".
    Comment puis-je remédier à ce problème?

    Merci de votre attention.

  2. #2
    Membre Expert Avatar de Jean-Pierre49
    Homme Profil pro
    Retraité
    Inscrit en
    Juillet 2007
    Messages
    659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2007
    Messages : 659
    Par défaut
    Bonjour à tout le forum,

    dans
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub Workbook_Open()
     
    TonUSF.Show
     
    End Sub
    Dans le module de TonUSF

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub TonUSF_Initialize()
     
    Ton Code
     
    End Sub

    Bon Courage

  3. #3
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Bonjour,

    Tu dois préciser où se situent tes combobox, il ne peut pas le deviner.
    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Private Sub Workbook_Open()
     
    With Userform1
       .ComboBox1.AddItem Worksheets("Feuil3").Range("A1")
       .ComboBox1.AddItem Worksheets("Feuil3").Range("A2")
     
       .Cable.AddItem Worksheets("Feuil3").Range("C1")
       .Cable.AddItem Worksheets("Feuil3").Range("C2")
       'etc...
     
        .Naturesol.AddItem Worksheets("Feuil2").Range("J35")
    End With
     
    End Sub

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2008
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 66
    Par défaut
    Bonjour fring,

    mes combobox ne se trouve pas sur userform, mai sous feuille excel "Feuil1"

    Si cette info peut t'aider....

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2008
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 66
    Par défaut
    Merci pour l'idée, fring

    J'obtiens donc le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    Private Sub Workbook_Open()
     
    With Feuil2
     
    .ComboBox1.AddItem Worksheets("Feuil3").Range("A1")
    .ComboBox1.AddItem Worksheets("Feuil3").Range("A2")
     
    .Cable.AddItem Worksheets("Feuil3").Range("C1")
    .Cable.AddItem Worksheets("Feuil3").Range("C2")
    .Cable.AddItem Worksheets("Feuil3").Range("C3")
     
    .rupteur.AddItem Worksheets("Feuil3").Range("A7")
    .rupteur.AddItem Worksheets("Feuil3").Range("A8")
     
    .ComboBox2.AddItem Worksheets("Feuil3").Range("A4")
    .ComboBox2.AddItem Worksheets("Feuil3").Range("A5")
     
    .pose.AddItem Worksheets("Feuil3").Range("F1")
    .pose.AddItem Worksheets("Feuil3").Range("F2")
    .pose.AddItem Worksheets("Feuil3").Range("F3")
    .pose.AddItem Worksheets("Feuil3").Range("F4")
    .pose.AddItem Worksheets("Feuil3").Range("F5")
     
    .Naturesol.AddItem Worksheets("Feuil2").Range("J31")
    .Naturesol.AddItem Worksheets("Feuil2").Range("J32")
    .Naturesol.AddItem Worksheets("Feuil2").Range("J33")
    .Naturesol.AddItem Worksheets("Feuil2").Range("J34")
    .Naturesol.AddItem Worksheets("Feuil2").Range("J35")
     
    End With
     
    End Sub
    PS : Je sais, c'est idiot, mais je ne m'étais pas rendu compte avant que ma feuille1 s'appelait "Feuil2" et que ma feuille2 s'appelait "Feuil1"

  6. #6
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Pour info, il y a 3 manières d'appeler une feuille
    1. par sa position (de gauche à droite)
    2. par son nom (Name)
    3. par son code (CodeName)


    Position = Sheets(1), Sheets(2), Sheets(3), etc...
    Nom = Sheets("toto")
    Code = Feuil1

    Dans ton éditeur Visual Basic tu apperçois ceci :
    Code Name --> Feuil1(Toto) <-- Name

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

Discussions similaires

  1. Multi-selection dans une ComboBox ?
    Par Moloko dans le forum MFC
    Réponses: 5
    Dernier message: 07/07/2021, 17h26
  2. [VB6] [Interface] ComboBox à plusieurs colonnes
    Par mtl dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 30/03/2004, 17h35
  3. [VB6] [Interface] Grille avec combobox
    Par khany dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 15/01/2003, 09h55
  4. combobox et readonly
    Par Mac leod dans le forum C++Builder
    Réponses: 6
    Dernier message: 28/11/2002, 10h27
  5. combobox->text
    Par clovis dans le forum C++Builder
    Réponses: 18
    Dernier message: 21/06/2002, 15h43

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