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 :

Enregistrer sous : comment récupérer dans une variable le nom du fichier sélectionné [XL-2016]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    85
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France

    Informations professionnelles :
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2007
    Messages : 85
    Par défaut Enregistrer sous : comment récupérer dans une variable le nom du fichier sélectionné
    Bonjour,

    Je copie un onglet dans un nouveau fichier. J'ouvre une boite de dialogue pour que l'utilisateur "enregistre sous" le nouveau fichier avec un nom que je propose. s'il clique sur OK, aucun problème car ayant proposé le nom du fichier, je l'ai dans une variable.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
     
    Sub EditionplanningCPFT()
    Dim NomFeuilOrigine, NomFeuilDest, NomClasseurCPFT As String
    Dim objWorkbookSource, objWorkbookCible As Workbook
     
    '...
     
    Application.DisplayAlerts = False
        On Error Resume Next
    ' copie l'onglet dans un nouveau classeur
    Worksheets(NomFeuilDest).Copy
    Application.Dialogs(xlDialogSaveAs).Show (NomClasseurCPFT + ".xlsx")
    With ActiveWorkbook
     
    'ferme le nouveau classeur pour revenir dans le classeur intial
        .Close SaveChanges:=False
    End With
    'Efface l'onglet copié dans le classeur intial
    Worksheets(NomFeuilDest).Delete
        Err.Clear
    Application.DisplayAlerts = True
    'réouvre le nouveau classeur et maintient le classeur initial derriére
    Set objWorkbookSource = Application.Workbooks.Open(NomClasseurCPFT + ".xlsx")
    Worksheets(NomFeuilDest).Activate
    End sub
    Par contre, si l'utilisateur sélectionne via la boite de dialogue un classeur pré-existant (i-e change le nom) puis accepte de remplacer le fichier préexistant, je ne peux pas ré-ouvrir le classeur... car je n'ai pas récupéré le nom sur lequel l'utilisateur a cliqué

    question : est-il possible de récupérer le nom du classeur (et le chemin d'accès) et si oui comment modifier le code?

    Merci

  2. #2
    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 171
    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 171
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Je sais pas comment récupérer le nom du classeur sélectionné à l'aide de l'instruction Application.Dialogs(xlDialogSaveAs)
    En revanche, tu pourrais utiliser la fonction GetSaveAsFilename pour récupérer ce nom

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub t()
      Dim FileName As String
      Dim FullName As Variant
      FileName = Format(Date, "yyyy-mmdd") & " - myWorkbook"
      shtSales.Copy ' Copie de la feuille dont le CodeName est shtSales vers un nouveau classeur
      FullName = Application.GetSaveAsFilename(InitialFileName:=FileName, fileFilter:="Excel Files (*.xlsx), *.xlsx")
      If FullName <> False Then
         ActiveWorkbook.SaveAs FullName ' Sauve le classeur
      End If
    End Sub
    Petite remarque
    Dans les deux lignes d'instructions ci-dessous, seule la dernière variable de chaque ligne est réellement typée. Les autres sont de type Variant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Dim NomFeuilOrigine, NomFeuilDest, NomClasseurCPFT As String
    Dim objWorkbookSource, objWorkbookCible As Workbook
    A lire Utiliser les variables en VBA Excel et tout particulièrement le chapitre II. Les types de données
    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

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    85
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France

    Informations professionnelles :
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2007
    Messages : 85
    Par défaut
    Merci beaucoup,
    Résultat parfait,
    xorbane

  4. #4
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Au lieu d'utiliser Dialogs(xlDialogSaveAs), utilise GetSaveAsFilename et SaveAs. Ce sera bien plus simple pour toi.

    Pour l'utilisateur, ce serait transparent mais pour toi le contrôle serait meilleur.
    Entre autre, tu pourrais vérifier si l'utilisateur souhaite vraiment enregistrer et sous quel nom avant de procéder véritablement à l'enregistrement.

    question : est-il possible de récupérer le nom du classeur (et le chemin d'accès) et si oui comment modifier le code?
    Etant donné que Dialogs(xlDialogSaveAs) ne peut agir que sur le classeur actif, il suffit, après sa ligne de code, de récupérer son chemin et son nom par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Chemin = ActiveWorkbook.Path
    Nom = ActiveWorkbook.Name

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    85
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France

    Informations professionnelles :
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2007
    Messages : 85
    Par défaut
    Salut,
    Merci pour le conseil.
    Cela fonctionne.
    Xorbane

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 07/04/2019, 10h13
  2. Réponses: 3
    Dernier message: 05/05/2011, 21h30
  3. Récupérer dans une variable la note de bas de page
    Par Manudibango dans le forum Général VBA
    Réponses: 6
    Dernier message: 03/12/2006, 17h27
  4. Réponses: 2
    Dernier message: 01/08/2006, 16h40
  5. Recuperer un enregistrement de requete SQL dans une variable
    Par kleenex dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 14/09/2005, 15h59

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