Bonjour à toutes et à tous !

Ce n'est pas faute d’avoir fouillé partout, mais je n'arrive pas à optimiser mon code... il est fonctionnel mais très lent avec les 12 "répétitions".

L'idée est de rapatrier les données contenues dans plusieurs fichiers ayant 2 onglets vers un seul et unique fichier disposant de ces mêmes 2 onglets structurellement identiques..

Le code joint, piqué chez vous, m'a permis d'avancer à grands pas, mais je doute de sa "propreté"...
Je crois qu'il me faut créer un module pour la requête... Me trompe-je ?

J'ai également constaté que lorsqu'un fichier est ouvert par un utilisateur, le fichier s'ouvre (un post à déjà été fait à ce propos, mais je n'ai pas compris la résolution..)

D'autant que je souhaiterai, dans la mesure du possible, rapatrier à tout le moins les couleurs des cellules.... => très accessoire !

Voici l'usine (néanmoins réduite puisque j'ai une douzaine de fichiers, mais l'esprit est celui ci) :
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
Sub Bouton3_Cliquer()
    Dim Cn As ADODB.Connection
    Dim FichierDAA As String
    Dim FichierDTEST 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
    FichierDAA = "\\services.ddn\partages\COMMUN_RESSOURCES_DGSol\DAA\Ressources humaines effectifs\Suivi des vacances et des recrutements\DAA.xlsm"
    FichierDTEST = "\\services.ddn\partages\COMMUN_RESSOURCES_DGSol\DTEST\Ressources humaines effectifs\Suivi des vacances et des recrutements\DTEST.xlsm"
 
    'Nom de la feuille dans le classeur fermé
    NomFeuille = "Postes vacants"
 
    Set Cn = New ADODB.Connection
 
    '--- Connexion ---
    With Cn
        .Provider = "Microsoft.Jet.OLEDB.4.0"
        .ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" _
            & FichierDAA & ";Extended Properties=""Excel 12.0;HDR=YES;"""
        .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
With Feuil1
    .Cells(.Rows.Count, "A").End(xlUp)(2).CopyFromRecordset Rst
End With
 
    '--- Fermeture connexion ---
    Cn.Close
    Set Cn = Nothing
 
 
' 2e requete
    Set Cn = New ADODB.Connection
 
    '--- Connexion ---
    With Cn
        .Provider = "Microsoft.Jet.OLEDB.4.0"
        .ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" _
            & FichierDTEST & ";Extended Properties=""Excel 12.0;HDR=YES;"""
        .Open
 
    End With
    '-----------------
 
    texte_SQL = "SELECT * FROM [" & NomFeuille & "$]"
 
    Set Rst = New ADODB.Recordset
    Set Rst = Cn.Execute(texte_SQL)
 
With Feuil1
    .Cells(.Rows.Count, "A").End(xlUp)(2).CopyFromRecordset Rst
End With
 
    '--- Fermeture connexion ---
    Cn.Close
    Set Cn = Nothing
 
End Sub
Merci de l'éclairage que vous pourrez apporter et surtout des commentaires que vous laissez partout qui permettent d'en apprendre beaucoup !!!