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 :

Accès classeur XLSX par ADO [XL-365]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Octobre 2020
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Consultant MOA
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2020
    Messages : 17
    Par défaut Accès classeur XLSX par ADO
    J'essaie d'accéder aux données d'un classeur XLSX par des requêtes SQL à l'aide de ADO.
    Le classeur en question comporte plusieurs feuilles, et, dans chacune d'elles, un tableau ListObject correctement structuré.
    J'arrive bien à ouvrir mon fichier, mais, lorsque j'interroge le schéma des tables, le OpenSchema(adSchemaTables).RecordCount est égal à -1.
    De même, lorsque j'essaie d'accéder à un listobject spécifique, j'ai le message suivant:

    Erreur d'exécution '-2147217865(80040e37)'

    Le moteur de base de données Microsoft Access n'a pas pu trouver l'objet t_comptes. Vérifiez qu'il existe et que vous avez ....
    Autrement dit, le système ne trouve pas de table dans mon fichier.

    Voici mon code:

    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
    Public Sub Essai()
    Dim Plage As Range
        Set Plage = Workbooks("Tests").Worksheets("Feuil1").Range("A1:B2")
        Call Extraction(Plage)
    End Sub
     
     
    Public Sub Extraction(rng As Range)
        Dim Source As ADODB.Connection
        Dim Rst As ADODB.Recordset
        Dim Fichier As String
        Dim Requete As String
     
        Fichier = "\\BETH-SALEM_NAS\Cloud Hubic\Famille_Administratif\Comptabilité\Développement procédure comptes\Comptes Familiaux - Données.xlsx"
        Requete = "SELECT [Libelle] FROM [t_Comptes] WHERE [Cle] = 25"
     
        Set Source = New ADODB.Connection
        With Source
            .Provider = "Microsoft.Jet.OLEDB.4.0"
            .ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" _
                & Fichier & ";Extended Properties=""Excel 12.0;HDR=YES;"""
            .Open
        End With
     
        Set Rst = New ADODB.Recordset
        Set Rst = Source.Execute(Requete)
     
        rng.Offset(1, 0).CopyFromRecordset Rst
     
        Rst.Close
        Source.Close
        Set Source = Nothing
        Set Rst = Nothing
    End Sub
    J'ai sûrement oublié quelque chose, mais quoi ?

    Merci pour votre aide

  2. #2
    Membre Expert Avatar de Thumb down
    Homme Profil pro
    Retraité
    Inscrit en
    Juin 2019
    Messages
    1 592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Juin 2019
    Messages : 1 592
    Par défaut
    Bonjour,
    Requete = "SELECT [Libelle] FROM [t_Comptes$] WHERE [Cle] = 25"

  3. #3
    Membre Expert Avatar de mfoxy
    Homme Profil pro
    Automation VBA
    Inscrit en
    Février 2018
    Messages
    752
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Belgique

    Informations professionnelles :
    Activité : Automation VBA
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2018
    Messages : 752
    Par défaut
    Bonsoir,

    Pour ce qui est de récupérer, en tout ou en partie, avec ou sans traitement ETL, des infos d'autres tables de fichier différents ou pas, je te conseillerais l'utilisation de PowerQuery.

    Tu pourras trouver un très bel exemple ,en vidéo de surcroît, sur ce site ,blog de Pierre Fauconnier.

    Bat

  4. #4
    Membre averti
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Octobre 2020
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Consultant MOA
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2020
    Messages : 17
    Par défaut Ca ne marche toujours pas
    Merci, mfoxy, pour ta proposition, mais j'aimerais d'abord me débrouiller correctement avec ADO avant d'aborder une autre technique.

    Merci, Thumb down.
    Dans mon classeur, "Comptes" est une Worksheet et "t_Comptes" est le ListObject qu'elle contient.
    Si je mets Requete = "SELECT [Libelle] FROM [t_Comptes$] WHERE [Cle] = 25" comme tu me le conseilles, le message d'erreur est "t_Comptes" n'est pas un nom valide....
    Si je mets t_Comptes, il ne trouve pas l'objet t_Comptes.
    Si je mets Comptes, il ne trouve pas l'objet Comptes
    Si je mets Comptes$, ça va un peu plus loin (donc il semble trouver la table) mais il plante sur l'instruction Set Rst = Source.Execute(Requete) avec le message "Aucune valeur donnée pour un ou plusieurs des paramètres requis".

    Si quelqu'un peut m'aider...

    Mais j'aimerais bien savoir comment lui passer un ListObject

    Par acquis de conscience, je viens de renommer t_Comptes en tComptes, et j'ai exactement les mêmes résultats

  5. #5
    Membre averti
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Octobre 2020
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Consultant MOA
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2020
    Messages : 17
    Par défaut Résolu
    J'ai finalement trouvé : mon problème venait de la clause "WHERE" dans la requête SQL. Quand on supprime cette clause, ça fonctionne bien. Maintenant, reste à trouver ce qui cloche dans cette clause!

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

Discussions similaires

  1. Contrôler l'accès au classeur actuel par d'autres utilisateurs
    Par Archampi dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 07/10/2008, 18h54
  2. Accès proc stock par ADO.
    Par maxx13 dans le forum MFC
    Réponses: 2
    Dernier message: 05/01/2007, 17h53
  3. Champs ftInteger reconnus en ftBCD par ADO
    Par pimousse9 dans le forum Oracle
    Réponses: 1
    Dernier message: 23/11/2005, 13h00
  4. Accès à un SGBD par internet
    Par debug dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 14/10/2005, 01h20
  5. Optimisation temps d'accès Bdd des composants ADO
    Par Creenshaw dans le forum Bases de données
    Réponses: 14
    Dernier message: 07/06/2005, 18h09

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