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 :

Choix du répertoire d'enregistrement et fichier en lecture seule


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Homme Profil pro
    Finance d'entreprise
    Inscrit en
    Juin 2016
    Messages
    178
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Finance d'entreprise
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2016
    Messages : 178
    Points : 89
    Points
    89
    Par défaut Choix du répertoire d'enregistrement et fichier en lecture seule
    Bonjour,

    J'importe régulièrement des fichiers depuis internet et aimerais que le bon répertoire apparaisse lorsque je les enregistre afin d'éviter de sélectionner le dossier approprié à chaque fois.

    La macro suivante me permet de sélectionner le dossier souhaité qui apparaîtra lors de l'enregistrement:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub RepParDéfaut()
     
            Dim rep As FileDialog
     
            Set rep = Application.FileDialog(msoFileDialogFolderPicker)
     
            rep.Show
            ChDir rep.SelectedItems(1)
     
    'Note:
    'Possible aussi: Application.DefaultFilePath = rep.SelectedItems(1)
     
    End Sub
    Cela fonctionne pour n'importe quel classeur y compris s'il est nouveau et en .xls, mais avec le fichier importé, ouvert sans être enregistré, c'est le répertoire "Bibliothèques\Documents" qui s'ouvre par défaut. Idem en remplaçant ChDir par Application.DefaultFilePath. Je suppose que c'est parce que le fichier importé est en lecture seule, mais au fond je n'en sais rien...

    Pensez-vous qu'une solution existe?

  2. #2
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Bonjour
    Pas vraiment clair ...
    Que veux-tu ? Que la boîte de dialogue s'ouvre sur un dossier particulier par défaut ?
    C'est la propriété InitialFileName de ton objet rep, qu'il faut alors utiliser.
    Ainsi (exemple) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Set rep = Application.FileDialog(msoFileDialogFolderPicker)
    rep.InitialFileName = "c:\"
    rep.Show
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

  3. #3
    Membre régulier
    Homme Profil pro
    Finance d'entreprise
    Inscrit en
    Juin 2016
    Messages
    178
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Finance d'entreprise
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2016
    Messages : 178
    Points : 89
    Points
    89
    Par défaut
    Ta macro avec InitialFileName affiche une boîte de dialogue permettant de choisir un répertoire à partir d'un chemin d'accès défini dans la procédure. Sauf erreur, ça ne fait pas de ce répertoire un dossier par défaut pour un autre usage, c'est-à-dire dans une autre boîte de dialogue. Ou Est-ce que je me trompe?

    La macro ne doit servir qu'une fois, au début de ma session, pour définir un dossier particulier par défaut. Ce répertoire s'ouvre automatiquement ensuite lorsque je veux enregistrer un classeur et en particulier lorsque je veux enregistrer un fichier importé d'internet.

    Si tu regardes ma macro, tu peux en déduire ce que je veux faire. Elle fonctionne lorsqu'il s'agit d'enregistrer un classeur non importé d'internet. Elle permet seulement de choisir un répertoire par défaut. Ensuite, lorsque j'enregistre un classeur, c'est ce répertoire par défaut qui s'affiche dans la boîte de dialogue d'enregistrement.

    Est-ce suffisamment clair?

  4. #4
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Toujours pas vraiment très clair
    A tout hasard :
    - on se réfère au répertoire courant par CurDir
    - J'appelle ton attention sur ce que tu peux lire dans ton aide interne VBA :
    L'instruction ChDir change le dossier par défaut mais pas le lecteur par défaut. Par exemple, si C est le lecteur par défaut, l'instruction ci-dessous change le dossier par défaut sur le lecteur D, mais C reste le lecteur par défaut :
    - le lecteur par défaut se spécifie par l'instruction ChDrive

    Je n'ai pas bien compris quel était ton problème, mais tu devrais pouvoir te servir de tout cela.
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

Discussions similaires

  1. Modifier ou supprimer fichier en lecture seule
    Par axel-erator dans le forum Langage
    Réponses: 2
    Dernier message: 01/12/2005, 17h57
  2. enregistrer deux fichier dans un seul fichier
    Par Bourak dans le forum Langage
    Réponses: 9
    Dernier message: 05/11/2005, 09h48
  3. Réponses: 8
    Dernier message: 09/08/2005, 11h44
  4. Réponses: 7
    Dernier message: 05/08/2005, 16h32
  5. [PDE] Editeur de fichiers en lecture seule
    Par simsky dans le forum Eclipse Java
    Réponses: 7
    Dernier message: 13/07/2005, 12h18

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