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 : Transfert listbox vers Excel


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut VBA Excel : Transfert listbox vers Excel
    Bonjour,

    je découvre les listebox et je galère...

    En fait, je recupère des données dans ma listbox, ça, ça ne pose pas de problème, il me les affiche dans mon formulaire. Cependant, je n'arrive pas à la transférer sur une feuille Excel.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    ...
    ListeTest.RowSource = ""
    For k = 0 To 29
        ListeTest.AddItem tabClassification(k)
    Next k
    ...
    Dans un premier temps j'ai essayé avec ce que j'ai trouvé sur http://silkyroad.developpez.com/VBA/ControlesUserForm/, j'ai donc fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    Dim wbTemp As Excel.Workbook
    Dim feuil As Worksheet
    Dim i As Long
     
    Set wbkTp = RecupClasseur 'fct qui recupere le classeur actif
     
    Set feuil = wbkTp.ActiveSheet
     
    With ListeTest
            feuil.Range(Cells(1, 1), Cells(.ListCount, 1)) = .List
        End With
    Mais il m'affiche le message d'erreur :
    "Erreur de compilation :
    Membre de méthode ou de données introuvables"
    Tout en me surlignant la partie ".List"

    Du coup, ne comprenant pas trop le code que j'avais "betement" collé de la page internet, j'ai tenté ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    flM.Cells(25, 1) = ListeTest.List(1)
    Mais rien n'y change, j'ai toujours le meme message d'erreur, et il me surligne toujours le .List.

    Malheureusement, je ne trouve nulpart de la doc assez précise sur les listBox pour comprendre ce que c'est ce .List (qui d'ailleurs n'apparait pas quand je fais ListeTest. [ctrl + espace ] )

    J'espère que quelqu'un pourra m'aider,

    je vous remercie d'avance,

    Secco

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

    Informations professionnelles :
    Activité : Engineering

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

    En supposant que tu transfères les données de ta ListBox via un bouton qui se trouve également sur ton UserForm

    Essaye ceci que tu pourras adapter
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub CommandButton1_Click()
    Dim i As Integer
     
    For i = 0 To ListeTest.ListCount - 1
        Cells(i + 1, 1) = ListeTest.List(i)
    Next
     
    End Sub

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    Tout d'abord merci de prendre le temps de réfléchir à mon problème

    Ensuite, j'ai essayé ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    For i = 0 To ListeTest.ListCount - 1
        feuil.Cells(i + 1, 1) = ListeTest.List(i)
    Next
    Comme tu me l'as suggéré, mais malheureusement, j'ai toujours le meme message d'erreur. Et à mon avis le problème vient de ce ".List" qui n'est meme pas accessible dans la liste des propriétés de ma listebox, mais je n'arrive toujours pas à trouver pourquoi...

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

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Non le problème ne vient pas de là, le code que je t'ai envoyé fonctionne.
    Commence par faire ce test
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox ListeTest.ListCount

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    Ca marche, j'ai une réponse : 30

    Mais toujours le meme message d'erreur avec ce .List surligné

    Et toi, quand tu fais le test, est ce que quand tu fais . [ctrl] tu as List ? Car je n'ai pas cette propriété de proposé et je trouve ça bizarre...

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

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Alors fais le test directement sur une feuille active, n'importe laquelle, en retirant ton feuil.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    For i = 0 To ListeTest.ListCount - 1
        Cells(i + 1, 1) = ListeTest.List(i)
    Next

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    Bon, je teste, je teste... rien ne marche, toujours la meme erreur.

    Et là, je me dis mais au fait, y'a une autre sorte de liste, les listes modifiables !

    Donc, déjà est ce que le .list ça marche que avec les listes modifiables par hasard ? ...

    Et ensuite, du coup j'ai recrée ma ListeTest avec une liste modifiable mais alors les ennuis commencent au moment de rentrer mes données dans ma liste !

    Bon fring, j'espère que tu vas pas m'abandonner, la solution approche (enfin j'espère !!)

    au faites, mon code pour remplir ma listebox (modifiable maintenant) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ListeTest.RowSource = ""
    For k = 0 To 29
        ListeTest.AddItem tabClassification(k)
    Next k
    et donc mon problème, ça met pas d'erreur, mais ça ne remplit pas ma listebox (modifiable)...

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

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    La "zone de liste modifiable" est un (ou une) ComboBox.
    La "zone de liste" est une ListBox.

    Ya pas raison de changer, cela doit fonctionner avec la ListBox.

    Je ne comprend vraiment pas d'où peut provenir l'erreur.
    Ci-joint un fichier avec le fonctionnement de la listbox selon le code que je t'ai proposé. Compare et essaye de trouver ce qui couine.

    Si toujours rien, envois un bout de fichier avec ton userform et tout le toutim

    Pièce jointe 29245

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    encore merci, je vais tester, ça à fond, de toute façon il faut que ça marche !

    je tiendrais au courant ici...
    (si entre temps si quelqu'un a aussi d'autres idées, merci)

  10. #10
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    En testant, je me rends compte, que je n'ai pas précisé un truc important quand meme c'est que mon formulaire il se trouve dans une formulaire ACCESS !

    Donc en fait,
    quand je fais mon formulaire access je fais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ListeTest.RowSource = ""
    For k = 0 To 29
        ListeTest.AddItem tabClassification(k)
    Next k
    Ensuite, quand on clique sur un bouton de ce formulaire, je fais ça :

    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
     
    Private Sub CMd_Excel_Click()
     
    Dim wbkTp As Excel.Workbook
    Dim feuil As Worksheet
    Dim i As Long
     
    Set wbkTp = recupClasseur
     
    Set feuil = wbkTp.ActiveSheet
     
    MsgBox ListeTest.ListCount
     
    For i = 0 To ListeTest.ListCount - 1
        feuil.Cells(i + 1, 1) = ListeTest.List(i)
    Next
     
    End Sub
    Et donc, ma listebox se remplie (j'utilise bien une listbox, la meme que au debut, donc pas une modifiable). Mais impossible de faire fonctionner la deuxième partie, le transfert sous Excel... :''(

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

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Citation Envoyé par Secco Voir le message
    En testant, je me rends compte, que je n'ai pas précisé un truc important quand meme c'est que mon formulaire il se trouve dans une formulaire ACCESS !
    je pouvais encore chercher longtemps...

    Désolé là je ne connais pas le fonctionnement, je ne manipule jamais Access

  12. #12
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    Désolé... j'avais omis ce point complétement important, mais normalement le code VBA et les controls fonctionnent de la meme manière...

    je ne trouve vraiment pas :'(

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

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Citation Envoyé par Secco Voir le message
    Désolé... j'avais omis ce point complétement important, mais normalement le code VBA et les controls fonctionnent de la meme manière...
    Oui sans doute, mais le problème (à mon avis) n'est pas dans la manipulation de la ListBox mais c'est la syntaxe pour transférer les données de la listbox se trouvant sur Access vers un classeur Excel et cette syntaxe je ne la connais pas.

  14. #14
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    Je n'ai toujours pas résolu ce problème... Je vais aller le mettre dans VBA ACCESS également,

    si quelqu'un comprend pourquoi je n'ai pas accès à la propriété .List de ma liste box, merci de m'expliquer

  15. #15
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Points : 5 537
    Points
    5 537
    Par défaut
    Bonjour,

    Because (lis donc ton aide en ligne) la propriété List d'une Listbox est un Array de chaines de caractères, où chacune des chaînes est un élément de la Listbox !
    La propriété List non accompagnée d'un index d'"article est forcémùent incomplète et ne signifie rien.

    Donc, ceci ne signifie rien et provoque une erreur largement prévisible car ne correspondant pas à la syntaxe attendue :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    feuil.Range(Cells(1, 1), Cells(.ListCount, 1)) = .List ' Manque l'index !

  16. #16
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    Dois je comprendre que je dois faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    feuil.Range(Cells(1, 1), Cells(.ListCount, 1)) = .List(1)
    Parce que ça.. ça ne marche pas

  17. #17
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Points : 63
    Points
    63
    Par défaut
    Solution donnée par LedZeppII dans la section forum VBA ACCESS :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    For i = 0 To Me.ListeTest.ListCount - 1
        feuil.Cells(1 + i, 1) = Me.ListeTest.ItemData(i)
    Next i
    Merci à tous ceux qui se seront cassé la tête pour m'aider !

    Le ME. reste encore un mystère pour moi..

  18. #18
    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 : 70
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Points : 24 327
    Points
    24 327
    Par défaut
    Me. signifie cet Userform-ci ou cette feuille-ci en fonction de l'endroit où est placé le code.

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

Discussions similaires

  1. Transfert données listbox vers excel
    Par biquet52 dans le forum IHM
    Réponses: 3
    Dernier message: 18/09/2008, 13h03
  2. Transfert de listbox vers Excel
    Par Secco dans le forum VBA Access
    Réponses: 3
    Dernier message: 28/04/2008, 19h32
  3. Transfert requette ver excel en VB
    Par mbokmahop dans le forum VBA Access
    Réponses: 8
    Dernier message: 07/06/2007, 15h51
  4. [Access2003] Exporter le contenu d'une listbox vers excel
    Par hoaxpunk dans le forum VBA Access
    Réponses: 1
    Dernier message: 24/05/2007, 17h56
  5. Réponses: 1
    Dernier message: 04/12/2006, 11h08

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