Macro pour convertir des fichiers csv en excel

MARIEGUENOT -  
MARIEGUENOT Messages postés 9 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour,

J'ai plusieurs fichiers (environ 150) de même structure au format CSV. Je souhaiterais les enregistrer au format xls et les rassembler dans une même feuille de calcul.
J'ai essayé une macro qui fonctionne mais qui laisse les fichiers en csv avec le séparateur.
Pouvez vous m'aider
voici le code

Sub Macro1()
Dim CH As String 'déclare la variable CH (CHemin d'accès)
Dim F As String 'déclare la variable F (Fichier)
Dim N As String 'déclare la variable N (Nom)

CH = "E:\FNAC\Extractions Hebdo\" 'définit le chemin d'accès CH (à adapter à ton cas)
F = Dir(CH & "*.csv") 'définit le premier fichier .csv du dossier ayant CH comme chemin d'accès
Do While F <> "" 'boucle tant qu'il existe des fichiers .csv
N = Replace(F, ".csv", "") 'définit le nom N (le nom du fichier sans l'extension)
Workbooks.Open CH & F 'ouvre le fichier F
ActiveWorkbook.SaveAs CH & N, FileFormat:=51 'enregistre le fichier au format Excel
ActiveWorkbook.Close 'ferme le fichier
F = Dir 'définit le prochain fichier .csv
Loop 'boucle
End Sub

Merci d'avance pour votre aide
Je suis en excel 2010


A voir également:

8 réponses

gbinforme Messages postés 14946 Date d'inscription   Statut Contributeur Dernière intervention   4 724
 
Bonjour,

Regardes cette fiche et tu as en fin de fiche un classeur à télécharger qui fait ce que tu veux réaliser.
0
MARIEGUENOT Messages postés 9 Date d'inscription   Statut Membre Dernière intervention  
 
Merci, bcp.
Toutefois la macro ne s'exécute pas, elle bugue sur cette ligne
ActiveWorkbook.SaveAs Filename:=Chemin & Fichier, FileFormat:=xlExcel9795
Peux tu m'aider ?
Merci d'avance
0
gbinforme Messages postés 14946 Date d'inscription   Statut Contributeur Dernière intervention   4 724
 
Bonjour,

Effectivement, le classeur sauvegardait en ancienne version excel, je te l'ai modifié en xlsx, cela devrait mieux aller. ;-)


https://www.cjoint.com/c/HFugIlsEUZl
0