Optimisation de macro : Rapatrier plusieurs fichiers excel sur un seul
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:
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 !!!