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 :

Utilisation de ADO


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2012
    Messages : 31
    Par défaut Utilisation de ADO
    Bonjour, j'ai fais à mon stage un programme afin de récupérer les données d'un autre fichier Excel fermé, j'ai utilisé ADO, ledit programme marche bien sur Excel2003, mais pas chez moi sur excel 2010, Comment y remédier ?

    J'ai utilisé ce site pour m'y inspirer :
    http://boisgontierjacques.free.fr/
    a l'index ADO, rien ne marche avec ma version d'excel, ça me met
    "Source de données introuvable et nom de pilote non spécifié"

    Merci de votre aide

  2. #2
    Membre averti
    Homme Profil pro
    Amateur
    Inscrit en
    Avril 2012
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Amateur

    Informations forums :
    Inscription : Avril 2012
    Messages : 49
    Par défaut BONSOIR /BONJOUR
    Il faudrait voir du côté des références en comparant entre les 2 versions les références installées notamment activer sur ton fichier "OLE automation". Au cas ou pour trouver les références, se placer dans l'éditeur de macros, puis menu OUTILS, puis Références, celles qui sont activées sont positionnées en haut du menu avec une coche, cordialement.

  3. #3
    Membre éprouvé
    Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2009
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Janvier 2009
    Messages : 133
    Par défaut propriete chaine de connexion
    Bonjour,

    Tout se joue dans la chaine de connexion notamment la partie "Extended Properties='Excel 12.0"

    En effet chaque version de microsoft office change au niveau de l'attribut Extended Properties=8.0 ou 12.0 ou 14.0 pour 2003 , 2007 2010 2012

    Je pense cela solutionne ton problème de connexion pour lire fichier excel fermé

    A vos claviers

  4. #4
    Invité
    Invité(e)
    Par défaut
    http://drq.developpez.com/vb/tutoriels/ADO/

    Il faut activer la référence Microsoft AtiveX Data Objects 2.x Library.

  5. #5
    Membre émérite

    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Ardèche (Rhône Alpes)

    Informations forums :
    Inscription : Octobre 2006
    Messages : 652
    Par défaut
    Bonjour,

    à partir de XL2007, il vaut mieux utiliser ce script de connexion

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Dim Source as object
     'connection au classeur
         Set Source = CreateObject("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

  6. #6
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2012
    Messages : 31
    Par défaut
    C'est surtout pour les recordset en fait ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
        ChDir ActiveWorkbook.Path
        Dim rs As ADODB.Recordset
        Set cnn = New ADODB.Connection
        cnn.Open "DRIVER={Microsoft Excel Driver (*.xls)};DBQ=" & _
        ThisWorkbook.Path & "\" & "donnees.xls"
     
        Set rs = cnn.Execute("SELECT Projet FROM liste_projet where Projet <>''")
        Sheets("donn").Range("L2:L65536").ClearContents
        Sheets("donn").Range("L2").CopyFromRecordset rs
        cnn.Close
    A savoir si l'on peut conserver la même méthode quoi

  7. #7
    Invité
    Invité(e)
    Par défaut
    Bonjour je te suggère d’utiliser cette méthode, là tu n’as pas besoin de tripatouiller les références du projet même tu n’en as pas besoin !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub test()
    Dim Connexion
    Set Connexion = CreateObject("ADODB.Connection")
    Select Case Application.Version
    Case "14.0"
        CSTRING = "Version 2010"
    Case "10.0"
         CSTRING = "Version ???"
    End Select
     Connexion.Open CSTRING
     Set OpenRecordSet = CreateObject("ADODB.Recordset")
      OpenRecordSet.Open Sql, Connexion, 1, 3
    End Sub

Discussions similaires

  1. Réponses: 3
    Dernier message: 10/06/2015, 10h34
  2. Réponses: 0
    Dernier message: 17/03/2010, 12h24
  3. Réponses: 3
    Dernier message: 18/09/2006, 17h42
  4. utilisation d'objets ADO pour CMS sur POSTGRESQL7.3.2
    Par turbok dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 10/10/2003, 10h29
  5. [ADO] Utilisation du TADOConnection
    Par Bidouille dans le forum Bases de données
    Réponses: 10
    Dernier message: 30/09/2003, 14h46

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