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 :

Affichage du résultat d'une requête dans une liste


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Janvier 2007
    Messages
    255
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2007
    Messages : 255
    Par défaut Affichage du résultat d'une requête dans une liste
    Bonjour

    J'ai un fichier Excel depuis lequel je peux lancer plusieurs formulaires.

    Dans un des formulaires j'ai une liste (13 colonnes) que je souhaite mettre à jour depuis une requête SQL dans une base Access.

    J'ai effectué la requête, l'ai exécuté puis récupéré l'ensemble des enregistrements.

    Mon souci est que pour avoir la liste de tous les enregistrements, j'utilise GetRows qui me retourne un tableau à 2 dimensions (13, nombre d'enregistrement)

    et que la liste ne comprend pas cette dimension mais attend plutôt un tableau (Nombre d'enregistrement, 13).

    Existe t'il un moyen de forcer la liste à bien prendre en compte mon tableau ?
    Faut il que je recopie tous les enregistrements dans un tableau ayant les bonnes dimensions ? Si oui, existe t'il une méthode simple et rapide ?

    D'avance merci pour votre retour
    Bonne journée

  2. #2
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    transpose ton tableau, pour inverser les lignes et les colonnes

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MonTableauBis = Application.Transpose(MonTableauDeDepart)
    MonTableauDeDepart (Nombre d'enregistrement, 13) devient MonTableauBis (13,Nombre d'enregistrement) (ou inversement !)

    attention, il ne faut pas que l'indice maximal d'une dimension dépasse 65534 (2* Integer) sinon la tranposition directe n'est pas possible et il faudra découper en blocs de 65534 Max

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonsoir,
    Le problème n'est pas a proprement parler du transpose qui fonctionne comme joe la précisé, mais le fait qu'une liste ne peut contenir plus de 10 colonnes!

  4. #4
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Par défaut
    Bonjour,

    Une ListBox peut contenir même plus de 20 colonnes mais la seule condition pour ça, c'est d'utiliser la propriété RowSource pour la remplir donc, il te faudrait passer par une feuille intermédiaire et définir la propriété RowSource dans ton code sur cette feuille !
    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
    33
    34
    35
     
    Private Sub UserForm_Initialize()
     
        Dim Plg As Range
     
        'par exemple sur feuille Feuil4
        Set Plg = DefPlage(Worksheets("Feuil4"), 1, 1)
     
        If Plg Is Nothing Then Exit Sub 'éventuellement un message !
     
        ListBox1.ColumnCount = Plg.Columns.Count
        ListBox1.RowSource = Plg.Address
     
    End Sub
     
    Function DefPlage(Fe As Worksheet, L As Long, C As Long) As Range
     
        On Error GoTo Fin
     
        With Fe
     
            Set DefPlage = .Range(.Cells(L, C), _
                           .Cells(.Cells.Find("*", .[A1], -4123, , _
                           1, 2).Row, .Cells.Find("*", .[A1], -4123, , _
                           2, 2).Column))
     
        End With
     
        Exit Function
     
    Fin:
     
        Set DefPlage = Nothing
     
    End Function

Discussions similaires

  1. Réponses: 30
    Dernier message: 12/05/2016, 21h57
  2. Résultat d'un champ d'une requête dans une variable
    Par PsychedeChed dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 11/01/2009, 13h50
  3. Réponses: 4
    Dernier message: 02/07/2008, 12h32
  4. Réponses: 2
    Dernier message: 02/06/2006, 12h26
  5. Réponses: 4
    Dernier message: 01/12/2005, 15h36

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