IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Procédure pour enregistrer sous avec intégration de la date et de l'heure dans nom fichier [XL-2013]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Ingénieur aéronautique
    Inscrit en
    Août 2017
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur aéronautique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2017
    Messages : 363
    Par défaut Procédure pour enregistrer sous avec intégration de la date et de l'heure dans nom fichier
    Bonjour,

    En fin de procédure je fais appel à la procédure ci-dessous pour enregistrer un backup du fichier.
    Je propose d'enregistrer le fichier proposé sur le bureau et je clique sur le bouton "enregistrer" sauf que le fichier n'est pas enregistré ??

    Des suggestions ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Sub SaveFile()
      Dim Filename As String
     
      If MsgBox("Do you want to save TEST on your local disk ?", vbQuestion + vbYesNo, "Confirmation Request") = vbYes Then
        Filename = "TEST_" & Format(Date, "yyyymmdd") & "_" & Format(Time, "hhmmss") & ".xlsm"
        With Application.FileDialog(msoFileDialogSaveAs)
          .Title = "Save File as"
          .InitialFileName = Filename
          .Show
        End With
      End If
    End Sub

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 133
    Par défaut
    Peut-être cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub CopiesurBureau()
     
        Dim Chemin As String
        Dim NomDossier As String
     
        Chemin = "C:\Users\fofo\Desktop\" 'A ajuster selon ton cas
     
        If MsgBox("Do you want to save TEST on your local disk ?", vbQuestion + vbYesNo, "Confirmation Request") = vbYes Then
            NomDossier = "TEST_" & Format(Date, "yyyymmdd") & "_" & Format(Time, "hhmmss") & ".xlsm"
            ActiveWorkbook.SaveCopyAs Chemin & NomDossier
        End If
     
    End Sub

  3. #3
    Membre éclairé
    Homme Profil pro
    Ingénieur aéronautique
    Inscrit en
    Août 2017
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur aéronautique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2017
    Messages : 363
    Par défaut
    Bonjour,

    Merci pour votre proposition. En fait j'essaie d'utiliser ce que Pierre Fauconnier me propose (texte en rouge). Il indique :

    Tu pourrais aussi utiliser les FileDialog. L'utilisateur pourrait alors choisir son dossier, voire le créer, en déléguant la création à Windows...

    Cela m'intéresse beaucoup car ainsi c'est windows qui se charge de gérer l'existence du dossier.

    Par contre pourquoi après avoir sélectionné le bureau rien ne s'enregistre ?

    Cdlt.
    Jérôme.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Sub SaveFile1()
      Dim Filename As String
     
      If MsgBox("Do you want to save TEST on your local drive ?", vbQuestion + vbYesNo, "Confirmation Request") = vbYes Then
        Filename = "TEST_" & Format(Date, "yyyymmdd") & "_" & Format(Time, "hhmmss") & ".xlsm"
        With Application.FileDialog(msoFileDialogSaveAs)
          .Title = "Save File as"
          .InitialFileName = Filename
          .Show
        End With
      End If
    End Sub

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 133
    Par défaut
    salut licpegpon

    en ajoutant la méthode .Execute ça devrait le faire

    https://excel.developpez.com/faq/?pa...cel#FileDialog
    https://docs.microsoft.com/fr-FR/off...methods-office


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub SaveFile1()
      Dim Filename As String
     
      If MsgBox("Do you want to save TEST on your local drive ?", vbQuestion + vbYesNo, "Confirmation Request") = vbYes Then
        Filename = "TEST_" & Format(Date, "yyyymmdd") & "_" & Format(Time, "hhmmss") & ".xlsm"
        With Application.FileDialog(msoFileDialogSaveAs)
          .Title = "Save File as"
          .InitialFileName = Filename
          .Show
          .Execute
        End With
      End If
    End Sub

  5. #5
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 182
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Petite suggestion.
    Pour le nom du classeur à sauver, j'opte toujours pour une cellule placée dans une feuille paramètre alimentée par une formule. Ainsi si le client choisi une autre syntaxe pour le nom de son classeur il suffit juste de modifier la formule dans le classeur sans toucher à la procédure VBA et pour le nom du répertoire où le classeur doit être sauvé, je fais de même.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  6. #6
    Membre éclairé
    Homme Profil pro
    Ingénieur aéronautique
    Inscrit en
    Août 2017
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur aéronautique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2017
    Messages : 363
    Par défaut
    Bonjour,

    Merci à Philippe Tulliez et Florent77.

    La modif proposée par Florent77 fonctionne !!!! Le fichier est bien enregistré par contre il me propose de l'enregistrer avec l'extension .xlsx alors que la procédure indique que le fichier doit être enregistré avec l'extension .xlsm ?? D'autre part serait-il possible de proposer un dossier d'enregistrement par défaut ? Merci beaucoup.

    Cdlt.
    Jérôme.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. enregistrer sous avec nom automatique
    Par liop49 dans le forum VBA Word
    Réponses: 4
    Dernier message: 26/01/2011, 19h03
  2. [VB] macro pour enregistrer sous
    Par CélineM dans le forum SDK
    Réponses: 1
    Dernier message: 07/06/2007, 13h28
  3. macro pour enregistrer sous
    Par macromega dans le forum Général VBA
    Réponses: 2
    Dernier message: 03/05/2007, 20h17
  4. [PHP-JS] Définir chemin pour enregistrer sous
    Par zia2 dans le forum Langage
    Réponses: 16
    Dernier message: 16/05/2006, 19h31
  5. Fenêtre Enregistrer sous avec TWebBrowser
    Par Chriss dans le forum Composants VCL
    Réponses: 2
    Dernier message: 15/03/2006, 22h01

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo