Bonjour,

Je souhaite mettre à jour à l'ouverture de fichiers Excels les données d'une liste présentes dans un autre classeur excel fermé.

J'ai trouvé sur internet (https://silkyroad.developpez.com/VBA/ClasseursFermes/) une macro utilisant le mode ADO prête à l'emploi si j'ose dire que j'ai mis dans une procédure à l'ouverture du fichier (Workbook open)

le problème, c'est que cela fonctionne uniquement si mon classeur source (LISTE_BDD.xlsx) est ouvert !? LOL

Je ne pense pas que cela provienne de ma version d'Excel (excel 10, versoin 14.0)...

Merci par avance de votre aide !


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
36
37
38
39
 
Private Sub Workbook_Open()
 
    Dim Cn As ADODB.Connection
    Dim Fichier As String
    Dim NomFeuille As String, texte_SQL As String
    Dim Rst As ADODB.Recordset
 
    'Définit le classeur fermé servant de base de données
    Fichier = "N:\13_APPLICATIONS_EXCEL\Applications_en_cours_de_Developpement\FS#1264 - MAJ de tous les applicatifs Excel - Liens ODBC & USERMDP\_APPLI MAJ\LISTE_BDD.xlsx"
    'Nom de la feuille dans le classeur fermé
    NomFeuille = "Feuil1"
 
    Set Cn = New ADODB.Connection
 
    '--- Connection ---
    With Cn
        .Provider = "Microsoft.Jet.OLEDB.4.0"
        .ConnectionString = "Data Source=" & Fichier & _
            ";Extended Properties=Excel 8.0;"
        .Open
    End With
    '-----------------
 
    'Définit la requête.
    '/!\ Attention à ne pas oublier le symbole $ après le nom de la feuille.
    texte_SQL = "SELECT * FROM [" & NomFeuille & "$]"
 
    Set Rst = New ADODB.Recordset
    Set Rst = Cn.Execute(texte_SQL)
 
    'Ecrit le résultat de la requête dans la cellule A2
    Range("G2").CopyFromRecordset Rst
 
    '--- Fermeture connexion ---
    Cn.Close
    Set Cn = Nothing
 
End Sub