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

Excel Discussion :

Enregistrer un document Word en PDF depuis une macro EXCEL 2007 [XL-2007]


Sujet :

Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juin 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Responsable des études

    Informations forums :
    Inscription : Juin 2014
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Enregistrer un document Word en PDF depuis une macro EXCEL 2007
    Bonjour,

    Je me tourne vers vous car je rencontre un souci d'enregistrement de fichier word en PDF.

    J'ai un fichier Excel qui me sert de "base de donnée" et un fichier Word qui me sert de modèle pour générer des bons de commande.
    Dans le fichier excel j'ai créé une macro qui ouvre le modèle, met à jour les champs en fonction des données contenu dans le fichier excel puis enregistre le document word.

    Pour enregistrer le document en format word (.docx), pas de souci avec le code suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WordDoc.SaveAs ActiveWorkbook.Path & "\BDC.docx", FileFormat:=wdFormatDocument
    Par contre imposible d'enregistrer le document en pdf.
    j'ai bien essayer le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    WordDoc.ExportAsFixedFormat OutputFileName:= _
            ActiveWorkbook.Path & "\BDC.pdf", ExportFormat:= _
            wdExportFormatPDF, OpenAfterExport:=True, OptimizeFor:= _
            wdExportOptimizeForPrint, Range:=wdExportAllDocument, From:=1, To:=1, _
            Item:=wdExportDocumentContent, IncludeDocProps:=True, KeepIRM:=True, _
            CreateBookmarks:=wdExportCreateNoBookmarks, DocStructureTags:=True, _
            BitmapMissingFonts:=True, UseISO19005_1:=False
    Mais ça m'affiche un message d'erreur: "Argument ou appelle de procédure incorrect"

    => Pourriez vous m'indiquer la commande à utiliser pour enregistrer un fichier word en PDF depuis une macro VBA Excel ?

    Merci d'avance

  2. #2
    Expert éminent sénior
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Points : 18 674
    Points
    18 674
    Par défaut

    Bonjour !

    Ouvrir déjà Word puis regarder dans l'aide VBA les paramètres de cette méthode vis à vis de l'objet rattaché …
    En utilisant depuis Word le Générateur de macros et en effectuant l'enregistrement manuellement en .pdf,
    un code est livré sur un plateau !

    Restera alors à l'adapter côté Excel.

    Pour une difficulté Word, penser aussi au forum dédié !

  3. #3
    Candidat au Club
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juin 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Responsable des études

    Informations forums :
    Inscription : Juin 2014
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    Bonjour Marc_L,

    C'est exactement ce que j'ai fais, c'est d’ailleurs grâce à l'enregistreur de macro de Word que j'ai obtenu le code suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    WordDoc.ExportAsFixedFormat OutputFileName:= _
            ActiveWorkbook.Path & "\BDC.pdf", ExportFormat:= _
            wdExportFormatPDF, OpenAfterExport:=True, OptimizeFor:= _
            wdExportOptimizeForPrint, Range:=wdExportAllDocument, From:=1, To:=1, _
            Item:=wdExportDocumentContent, IncludeDocProps:=True, KeepIRM:=True, _
            CreateBookmarks:=wdExportCreateNoBookmarks, DocStructureTags:=True, _
            BitmapMissingFonts:=True, UseISO19005_1:=False
    Ce code fonctionne correctement s'il est exécuté dans une macro Word, mais pas depuis une macro Excel.

    Cependant, depuis mon premier message, j'ai trouvé la source du problème.
    Cela venait du fait que certain paramètre sont connu sous Word et pas sous Excel:
    Sous word :
    - wdExportFormatPDF=17
    -wdExportOptimizeForPrint=0
    - wdExportAllDocument=0
    - wdExportDocumentContent=0
    - wdExportCreateNoBookmarks=0
    Sous Excel tous ces paramètres étaient vides, donc logiquement le code ne fonctionnait pas.

    Avec le code ci-dessous, la macro fonctionne parfaitement sous Excel:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    WordDoc.ExportAsFixedFormat OutputFileName:= _
            ActiveWorkbook.Path & "\BDC.pdf", ExportFormat:= _
            17, OpenAfterExport:=True, OptimizeFor:= _
            0, Range:=0, From:=1, To:=1, _
            Item:=0, IncludeDocProps:=True, KeepIRM:=True, _
            CreateBookmarks:=0, DocStructureTags:=True, _
            BitmapMissingFonts:=True, UseISO19005_1:=False

  4. #4
    Expert éminent sénior
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Points : 18 674
    Points
    18 674
    Par défaut



    Exact en liaison tardive !

    Par contre en liant la référence Word au projet, en liaison anticipée donc, pas de souci …

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 17/05/2015, 00h48
  2. [XL-2003] savegarder dans un meme document word depuis une macro Excel
    Par jabranejb dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 04/12/2012, 23h51
  3. Lancer un pps depuis une macro Excel
    Par jalseth dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 09/06/2008, 17h19
  4. Ouvrir un fichier pdf depuis une macro
    Par Maluje dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 28/03/2008, 18h51
  5. [VBA-E] Execution d'un programme Perl depuis une macro Excel
    Par DaBeam dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 23/09/2007, 16h21

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