Export d'une copie au format xlsx

Résolu
daniel_1912 Messages postés 13 Statut Membre -  
daniel_1912 Messages postés 13 Statut Membre -
Bonjour à tous et toutes,
Voila je suis confronté à un léger problème.
Je remplis un fichier via un autre, juste là tout va bien. Sur ce fichier il y a une macro (format du fichier xlsm) . Ce dernier doit être transmis au format xlsx. J'aimerai donc enregistrer le fichier source sous un autre format (passer du xlsm au xlsx) sans fermer celui sur le lequel je travaille (pour en générer plusieurs).

Pour résumer simplement j'aimerai réaliser un export d'une copie du fichier au format xlsx le tout en lui donnant un nom moi même (comme dans enregistrer sous classique).

Pour le moment je me débrouille avec un bon vieux :

ActiveWorkbook.SaveCopyAs "C:\TEMP\XXXX.XLS

Sauf que :
-je ne suis pas toujours sur le même poste donc le chemin du desktop n'est pas le même partout
-le fichier a toujours le même nom je ne peux pas en générer plusieurs sans renommer le premier

Voila si quelqu'un a une idée de comment réaliser ceci sous vba

D'avance merci et bonne journée

Configuration: Windows / Chrome 81.0.4044.129

3 réponses

  1. jordane45 Messages postés 30426 Date d'inscription   Statut Modérateur Dernière intervention   4 830
     
    Bonjour,

    Pour ce qui est du chemin, pourquoi ne pas te baser sur le chemin du classeur actuel
    sFolderPath  = ActiveWorkbook.Path
    


    Et pour ce qui est du nom du fichier, un prompt ( inputbox) correspondrait à tes besoins
    https://docs.microsoft.com/fr-fr/office/vba/api/excel.application.inputbox

    .
    1
    1. daniel_1912 Messages postés 13 Statut Membre
       
      Effectivement c'est une bonne idée je vais me pencher dessus, merci. je vais voir pour intégrer ceci.
      0
  2. yg_be Messages postés 23437 Date d'inscription   Statut Contributeur Dernière intervention   Ambassadeur 1 588
     
    bonjour, quand tu écris "tout en lui donnant un nom moi même", qui est "moi-même": le programme, ou l'utilisateur? souhaites-tu ouvrir une boite de dialogue permettant à l'utilisateur de choisir le nom de destination?

    alors:
    Dim destfilename
    destfilename = Application.GetSaveAsFilename(ThisWorkbook.Path, "Excel xlsx Files,*.xlsx")
    If destfilename <> False Then
        ActiveWorkbook.SaveCopyAs destfilename
    Else
        ' "CANCELLED"
    End If
    1
    1. daniel_1912 Messages postés 13 Statut Membre
       
      Bonjour,
      Par "moi-même" je pensais à l'ouverture d'une boite de dialogue où le nom du fichier serait rentré par l'utilisateur .
      0
    2. daniel_1912 Messages postés 13 Statut Membre
       
      Après petit test cela fonctionne j'ai bien mon fichier où je souhaite et il est crée mais impossible de l'ouvrir il me dit que "l’extension ou le format n'est pas valide".
      0
      1. yg_be Messages postés 23437 Date d'inscription   Statut Contributeur Dernière intervention   1 588 > daniel_1912 Messages postés 13 Statut Membre
         
        en effet, SaveCopyAs ne change pas le type de fichier.
        0
      2. daniel_1912 Messages postés 13 Statut Membre > yg_be Messages postés 23437 Date d'inscription   Statut Contributeur Dernière intervention  
         
        Au final même il y a un petit couac je pense trouver une application a ceci merci encore
        0
  3. cs_Le Pivert Messages postés 8437 Statut Contributeur 730
     
    Bonjour,

    comme ceci:

    Dim destfilename
    destfilename = Application.GetSaveAsFilename(ThisWorkbook.Path, "Excel xlsx Files,*.xlsx")
    If destfilename <> False Then
    ActiveWorkbook.SaveAs Filename:= _
            destfilename, FileFormat:= _
            xlOpenXMLWorkbook, CreateBackup:=False
    Else
        ' "CANCELLED"
    End If

    1
    1. daniel_1912 Messages postés 13 Statut Membre
       
      Ha super ce code marche du tonnerre de Brest Merci beaucoup !
      0