Sélectionner plusieurs fichiers et changer leur extension
Résolu
muiigisha
Messages postés
61
Statut
Membre
-
muiigisha Messages postés 61 Statut Membre -
muiigisha Messages postés 61 Statut Membre -
Bonjour,
je souhaite sélectionner plusieurs fichiers d'extensions"csv" dans une boîte de dialogue et ensuite changer leur entennsion en "xlsm" mais j'ai l'erreur 424 qui s'affiche et je ne vois toujours pas comment procéder pour y rémédier. mon code ci dessous
Merci d'avance pour votre aide
je souhaite sélectionner plusieurs fichiers d'extensions"csv" dans une boîte de dialogue et ensuite changer leur entennsion en "xlsm" mais j'ai l'erreur 424 qui s'affiche et je ne vois toujours pas comment procéder pour y rémédier. mon code ci dessous
Sub Sauvegarde()
Dim Wbk As Variant
Dim Fichier As String
Dim QuelFichier()
QuelFichier = Application.GetOpenFilename(, , , , True)
For Each Wbk In QuelFichier
If Wbk.Name <> ThisWorkbook.Name Then
Fichier = Replace(Wbk.Name, "csv", "xlsb")
Wbk.SaveAs Fichier, FileFormat:=xlExcel12, CreateBackup:=False
Wbk.Close
End If
Next Wbk
End Sub
Merci d'avance pour votre aide
A voir également:
- Changer l'extension de plusieurs fichiers en même temps
- Changer dns - Guide
- Renommer plusieurs fichiers en même temps - Guide
- Changer extension fichier - Guide
- Excel trier plusieurs colonnes en même temps - Guide
- Changer clavier qwerty en azerty - Guide
4 réponses
Bonjour,
En première analyse, je pense qu'il manque le nom complet du fichier, c'est à dire :
En première analyse, je pense qu'il manque le nom complet du fichier, c'est à dire :
Wbk.SaveAs Thisworkbook.Path & "\" & Fichier, FileFormat:=xlExcel12, CreateBackup:=False
essayer ce code
Sub Sauvegarde()
Dim QuelsFichiers(), fichier As Variant, ext_fichier As String, wbk As Workbook
QuelsFichiers = Application.GetOpenFilename(, , , , True)
For Each fichier In QuelsFichiers
ext_fichier = Right(fichier, Len(fichier) - InStrRev(fichier, "."))
If ext_fichier = "csv" Then
Set wbk = Workbooks.Open(fichier)
fichier = Replace(fichier, "csv", "xlsb")
wbk.SaveAs fichier, FileFormat:=xlExcel12, CreateBackup:=False
wbk.Close
End If
Next fichier
End Sub
Bonjour Thev,
quand je compile le code ça met erreur 1004:run time:(
j'ai une question aussi est ce qu'on est contraint d'ouvrir les fichiers avant de changer les extensions ?
c'est le seul moyen que j'ai trouvé mais vous pouvez me proposer d'autres solutions. le changement des extensions n'est qu'une étape dans mon travail si ça met trop de temps en plus des autres procédures il y en qui vont râler.
Merci d'avance pour votre aide
quand je compile le code ça met erreur 1004:run time:(
j'ai une question aussi est ce qu'on est contraint d'ouvrir les fichiers avant de changer les extensions ?
c'est le seul moyen que j'ai trouvé mais vous pouvez me proposer d'autres solutions. le changement des extensions n'est qu'une étape dans mon travail si ça met trop de temps en plus des autres procédures il y en qui vont râler.
Merci d'avance pour votre aide
Une extension correspond à un format précis de fichier. Changer l'extension signifie changer son format. Une conversion est donc nécessaire et cette conversion est assurée par Excel. Ouverture + enregistrement est donc nécessaire pour que la conversion du format soit exécutée.
Je n'ai pas sur ma version d'Excel 2013 d'erreur d'exécution. Au niveau de quelle instruction avez-vous cette erreur ? Quelle version d'Excel utilisez-vous ?
Je n'ai pas sur ma version d'Excel 2013 d'erreur d'exécution. Au niveau de quelle instruction avez-vous cette erreur ? Quelle version d'Excel utilisez-vous ?
Ah d'accord je comprends tout à fait.
Déja j'ai changé "xlsb" en "xlsx" (car je veux en fait des feuilles de calculs tout simplement à moins que ça ne soit pareil...je ne sais vraiment pas)
J'utilise au Excel 2016 et l'erreur c'est au niveau de
et le message dit:
this extension can not be used with the selected file type. change the file extension in the file name text box or select a different file type by changing the save as type
Déja j'ai changé "xlsb" en "xlsx" (car je veux en fait des feuilles de calculs tout simplement à moins que ça ne soit pareil...je ne sais vraiment pas)
J'utilise au Excel 2016 et l'erreur c'est au niveau de
wbk.SaveAs fichier, FileFormat:=xlExcel12, CreateBackup:=False
et le message dit:
this extension can not be used with the selected file type. change the file extension in the file name text box or select a different file type by changing the save as type
FileFormat:=xlExcel12 signifie extension xslb, ça me parait donc logique qu'un conflit se produise.
2 solutions :
ou
2 solutions :
Set wbk = Workbooks.Open(fichier)
wbk.SaveAs Fichier, FileFormat:=xlOpenXMLWorkbook, CreateBackup:=False
ou
Set wbk = Workbooks.Open(fichier)
Fichier = Replace(Fichier, "csv", "xlsx")
wbk.SaveAs Fichier, CreateBackup:=False
mais je ne voudrais faire appel aux chemeins parce que après le travail que je fais sera utilisé par d'autres j'ai juste besoin d'une boîte de dialogue. Et quand je fais l'espion mes variables restent vides:(
comment puis je faire svp?
Merci d'avance
Voilà ce que j'ai fait ci-dessous
Ci-dessous code