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 :

Execution d'une macro sans ouverture du fichier


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné
    Avatar de mhamedbj
    Profil pro
    Inscrit en
    Février 2007
    Messages
    403
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 403
    Par défaut Execution d'une macro sans ouverture du fichier
    Re bonjour !!!

    Alors voila, j'ai un programme JAVA qui me génère un fichier excel avec plein de donnée et plein de cellules fusionnée et tout et tout (assez compliqué d'ailleurs j'ai pas accès à ce programme je ne récupère que le fichier de sortie .. bref)

    J'ai mis en place une macro qui met un forme ce fichier (mise en page, couleur, police) affin d'en faire un truc propre .. du coup tout le monde au boulot veulent ma macro, le truc c'est qu'ils ne doivent rien modifier sur le fichier avant d'avoir exécuter cette macro si non elle bug !!!

    Alors je suis ouvert à toutes sorte d'idée .. j'ai pensé a un truc qui exécute la macro sur un fichier directement sans l'ouvrir comme ça quand on l'ouvre il est déjà prêt ....mais bon je ne sais pas jusqu'où peut aller Excel donc ...

    PS: ne me dites pas de dire à mes collègues de ne rien toucher avant d'exécuter la macro je l'ai fait pour tant je n'arraite pas de reçevoir des coup de fil " hey elle marche pas !! " et ça commence à ....


    Cdt
    Mhamed

  2. #2
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    Tu ne peux pas lancer une macro dans un fichier fermé;
    par contre, tu peux lancer la macro à l'ouverture du fichier. Suffit que tu la lances depuis la Macro Workbook_Open placée dans ThisWorkbook
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub Workbook_Open()
          Call LaMacro
    End Sub
    Ta macro "LaMacro" étant dans un module standard... Ainsi elle s'exécutera avant toute modif dans les feuilles.
    A+

  3. #3
    Membre chevronné
    Avatar de mhamedbj
    Profil pro
    Inscrit en
    Février 2007
    Messages
    403
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 403
    Par défaut
    Citation Envoyé par ouskel'n'or Voir le message
    Ta macro "LaMacro" étant dans un module standard... Ainsi elle s'exécutera avant toute modif dans les feuilles.
    A+
    Excuse moi mais j'ai pas très bien compris.

    Voila moi comment je procède :

    J'ai un fichier XLS vide qui ne contient rien(que je laisse toujours vide), il s'appel MiseEnForme.XLS, dans le quel j'ai placé mon code, le nom de la fonction qui fait tout s'appelle Quand je reçoit un fichier du prog, disons fichier1.xls, alors j'ouvre mon fichier MiseEnForme.xls, je le laisse de côter, et je reviens à mon fichier1.xls, et quand je vais dans le menu Outil -> Macro -> Macros...

    j'ai accès à "MiseEnForme.xls!MiseEnFormeFichier" et je fais exécuter.


    Je ne vois pas comment appliquer ce que tu dis dsl

    Cdt
    Mhamed

  4. #4
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    Ok. Tu as deux fichiers.
    Le fichier à mettre en forme est un autre fichier que celui qui contient la macro. C'est le fichier "fichier1.xls" de ton exemple.
    A ce que je comprends, tu ne peux pas placer de macro dans ce fichier (tu confirmes ?)
    Tu dois donc mettre en forme "fichier1.xls" à l'ouverture
    C'est bien ça ?
    Comment ouvres-tu ce classeur ?
    Peux-tu confirmer mes interrogations et répondre à ma question ?
    A+

  5. #5
    Membre chevronné
    Avatar de mhamedbj
    Profil pro
    Inscrit en
    Février 2007
    Messages
    403
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 403
    Par défaut
    Citation Envoyé par ouskel'n'or Voir le message
    tu ne peux pas placer de macro dans ce fichier (tu confirmes ?)
    Je fais un copier coller du code à chaque fois ?, c'est ça placer une macro ?

    Pour moi une macro c'est un fichier XLS après je fais alt+F11 et après je fais un nouveau module et j'ecris mon code et je nomme mon fichier XLS comme le nom de la fonction et quand j'ai besion d'une macro, j'ouvre le fichier XLS correspondant

    Citation Envoyé par ouskel'n'or Voir le message
    Tu dois donc mettre en forme "fichier1.xls" à l'ouverture
    C'est bien ça ?
    oui

    Citation Envoyé par ouskel'n'or Voir le message
    Comment ouvres-tu ce classeur ?
    je reçoit un fichier XLS par mail .. quand je double clique dessus .... il s'ouvre ... oui alors je clique une fois et je tape 'Enter'

    Citation Envoyé par ouskel'n'or Voir le message
    Peux-tu confirmer mes interrogations et répondre à ma question ?
    Oui ... c'est ce que je viens de faire

    Citation Envoyé par ouskel'n'or Voir le message

    A+
    J'espère bien .. tu as l'ai de ty connaitre !

    Merci d'avance !

  6. #6
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    Bon, ça pose un pb pour le formater à l'ouverture. D'où les questions suivantes :
    1 - Où se trouve ton fichier ? dans une répertoire, ok mais...
    2 - Se trouves-t-il toujours au même emplacement ?
    3 - As-tu d'autres fichiers dans cet emplacement ?
    4 - Si oui, qu'est-ce qui différencie leurs noms ?
    5 - Si impossible de le savoir, peut-on au moins le reconnaître par la date de création ? (le dernier créé du répertoire par exemple)
    Désolé de ne pas encore te répondre mais la solution passe par là...
    A+

  7. #7
    Inactif  
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 054
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 054
    Par défaut
    Bonjour,
    Ce serrais pas plus simple de voir pourquoi ta macro bugge et de faire une détection d'erreur avec des on Error..
    A+

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/04/2012, 17h01
  2. Executer une macro à l'ouverture
    Par moilou2 dans le forum VBA Access
    Réponses: 9
    Dernier message: 28/05/2008, 09h35
  3. exécution d'une macro sans ouvrir le fichier
    Par sash6 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 07/05/2008, 11h49
  4. Impossible d'executer une macro d'un autre fichier
    Par gilles06 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 06/02/2008, 19h36
  5. Lancer une macro à l'ouverture d'un fichier
    Par Tibaldus dans le forum VBA Word
    Réponses: 2
    Dernier message: 12/09/2007, 11h27

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