VIVEZ LE
FOOTBALL !

Posez votre question Signaler

VBA macro pour convertir en pdf

Canard007 5954Messages postés 26 mai 2004Date d'inscription - Dernière réponse le 27 avril 2012 à 00:07
Bonjour à tous,

je recherche une macro vba pour convertir un fichier .xls en pdf.
Mes contraintes, utilisation de PDFMaker et Acrobat Reader 5.0.
Aprés moult recherche sur le net j'ai trouvé ce petit bout de code:

Const ThePath As String = "C:\XLD-PDF\"
Const TheFile As String = "TheTestingFile.PDF"
Sub Test()
CreePDFOnly True
End Sub

Sub CreePDFOnly(Optional PromptForPDFName As Boolean)
If ActiveWorkbook.Saved And Not PromptForPDFName Then
SendKeys "~"
ConvertToPDFA
ElseIf ActiveWorkbook.Saved And PromptForPDFName Then
SendKeys ThePath & TheFile + "~"
ConvertToPDFA
End If
End Sub

Le probléme est que lorsque je "passe" sur la ligne ConvertToPDFA
une message box me dit qu'il n'y a rien à ècrire et excel se bloque (je precise que le workbook actif et bien celui que je veux convertir).
Quelqu'un a il une idée d'ou peut venir cet effet?
Quelqu'un sait il ou je pourrai trouver la doc du PDFmaker.xla?
Ou mieux quelqu'un a t'il une macro qui fonctionne avec PDFMaker?

En vous remerciant d'avance, bonne année à toutes et à tous

Cordialement



COIN!
Lire la suite 

VBA macro pour convertir en pdf »

Suggestions
14 réponses
Réponse
+21
moins plus
Pour ceux qui comme moi ont galéré avant de trouver la réponse, voilà un code qui fonctionne avec PdfCreator:

Sub ToPdf()

Set pdfjob = CreateObject("PDFCreator.clsPDFCreator")
NomExcel = ThisWorkbook.Name
NomPdf = Left(NomExcel, Len(NomExcel) - 4) & ".pdf"
With pdfjob
If .cstart("/NoProcessingAtStartup") = False Then
MsgBox "Can't initialize PDFCreator.", vbCritical + vbOKOnly, "PrtPDFCreator"
Exit Sub
End If
.cOption("UseAutosave") = 1
.cOption("UseAutisaveDirectory") = 1
.cOption("AutosaveDirectory") = ThisWorkbook.Path
.cOption("AutosaveFilename") = NomPdf
.cOption("AutosaveFormat") = 0
.cClearCache
End With
ThisWorkbook.PrintOut copies:=1, ActivePrinter:="PDFCreator"
Do Until pdfjob.cCountOfPrintjobs = 1
DoEvents
Loop
pdfjob.cPrinterStop = False
Do Until pdfjob.cCountOfPrintjobs = 0
DoEvents
Loop
With pdfjob
.cDefaultprinter = DefaultPrinter
.cClearCache
.cClose
End With
Set pdfjob = Nothing
End Sub
2xpi- 2 févr. 2010 à 10:45
Bonjour Loulou,

Je viens de lire avec graaannde (!! ça fait aussi longtemps que je cherche !!!) attention ton message qui explique le lancement de pdfcreator merci beaucoup !

Je rencontre le même problème, en effet j'utilise pdfcreator pour convertir des courriels dans outlook. Pour ce faire, je lance une application word via le vba dans outlook, dans laquelle j'appelle le pdfcreator ... sauf que celui-ci ... ne vient pas !

Aurais-tu une idée qui expliquerait cela ?

Merci !

2xpi.

Impression avec PDFcreator dans WORD
        Set wordapp = CreateObject("Word.Application")
        Set wordDoc = wordapp.Documents.Open(strChemin & "\" & NomTransfert_doc)
        wordapp.Visible = True
 
        With wordapp.Selection
        .TypeParagraph
        .TypeText Text:=Item.SenderName
        .TypeParagraph
        .TypeText Text:=Item.Body
        .TypeParagraph
        End With

        Set pdfjob = CreateObject("PDFCreator.clsPDFCreator")
        With pdfjob
            If .cstart("/NoProcessingAtStartup") = False Then
                MsgBox "Initialisation de PDFCreator impossible", vbCritical + vbOKOnly, "PrtPDFCreator"
                Exit Sub
            End If
        .cOption("UseAutosave") = 1
        .cOption("UseAutosaveDirectory") = 1
        .cOption("AutosaveDirectory") = strChemin
        .cOption("AutosaveFilename") = NomPDF
        .cOption("AutosaveFormat") = 0 '0 pour pdf
        .cClearCache
        End With
        ActivePrinter = "PDFCreator"
        Application.PrintOut copies:=1
        'ActiveDocument.PrintOut copies:=1, ActivePrinter:= "PDFCreator"
        Do Until pdfjob.cCountOfPrintjobs = 1
        DoEvents
        Loop
        pdfjob.cPrinterStop = False
        Do Until pdfjob.cCountOfPrintjobs = 0
        DoEvents
        Loop
        With pdfjob
        .cDefaultprinter = DefaultPrinter
        .cClearCache
        .cClose
        End With
nad86 - 24 févr. 2010 à 14:47
génial loulou, vraiment génial, ça marche très bien et c'est ce que je cherchais

mais j'aurais une question, je n'y connais pas grand chose en programmation et il me faut, en plus de mettre en pdf toutes mes feuilles du classeur, que dans le nom du pdf il y ai en plus la date de la formaion de ce pdf

je ne sais pas si je me suis bien expliquée

en tout cas merci beaucoup, si quelqu'un peut m'aider.... c'est très important

biz

nad
Tom - 27 avril 2012 à 00:07
Juste un grand merci!
Ajouter un commentaire
Réponse
-2
moins plus
;-)

En fait, ce que tu dois lire, dans ce bout de code, c'est qu'il fait appel à un programme, ou un appilcation complémentaire ("ConvertToPDFA"), et que celui-ci, apparamment, a un blème....

Un truc qu'il faut savoir, c'est que quand tu installes une appli, celle-ci va inscrire ses bibliothèque de routines dans le registre, en l'occurence, Acrobat Reader... Le blème, c'est que Reader, c'est clair, comme message !! ;-))))) C'est pas Maker !! Acrobat Reader te permet de lire, pas de créer !

Si tu veux disposer des biblio pour créer, il te faut Acrobat TOUT COURT, pas Reader... Où alors tu utilises des trucs qui sortent des chemins Adobe... PDF Maker est une fonction d'Acrobat, pas du Reader qui n'est fait que pour lire... Sinon, il existe aussi des trucs pour créer au format PDF, mais je ne le garanti pas à 100%...

Bref, si tu veux faire des PDF en bonne et due forme, vas voir plutôt du coté d'Acrobat... Et c'est tellement plus simple...


Wild and Free
Yannick Rousseau - 12 déc. 2005 à 14:43
Bonjour,

J'ai exactement le même soucis, sauf que moi j'ai bien Acrobat 5.0 installé. Et j'ai bien référencé le module PDFMaker.xla dans le fichier contenant la macro... et pourtant ça bloque aussi au moment de la convertion (le processus excel prends 100%).

Que faire ?

Merci
blux- 12 déc. 2005 à 15:37
Salut,

une soluce, plus simple à gérer (sur un seul poste) est d'installer une imprimante PDF (le site de sebsauvage indique comment faire) et ensuite imprimer en choisissant celle-ci...

Qu'en penses-tu ?
Nyarta - 23 janv. 2006 à 16:19
J'en pense que l'imprimante PDF est déjà installée, puisqu'elle est livrée avec Acrobat 5, mais je veux que la conversion se fasse automatiquement, sans intervention de l'utilisateur, directement depuis le code VBA. Quant à installer une autre imprimante PDF, d'une part, j'ai déjà celle d'Acrobat, ensuite je n'ai pas le droit d'installer autre chose sur mon poste dans ma boîte et surtout, mon application doit être portable dans ma boîte donc je dois utiliser Acrobat.
Ajouter un commentaire
Réponse
-3
moins plus
Bj,
J'ai eu le meme pb.
Simplement il ne faut pas oublier de rajouter les librairies correspondantes dans ta feuille xl.

Pour cela tu vas dans Ms VBA et tu ouvres "OUTILS / PREFERENCES" et la tu rajoutes "PDFMaker" ou "Distiller " ..

Slts
Vince
Ajouter un commentaire
Réponse
-3
moins plus
Bonjour,

je cherche une macro qui me permettrait de créer, à partir d1 fichier excel, un pdf (Pdf Creator),
Le nom du fichier pdf serait une concaténation d'une cellule A1;"-";B1 de la feuille imprimée.
Le fichier pdf serait à envoyer toujours dans le même repertoire ex : "dossier1"

Je souhaite que le fichier pdf reste ouvert pour visualisation et soit fermé manuellement.

Est-ce possible ?

Merci d'avance pour toute indication
Ajouter un commentaire
Réponse
-3
moins plus
Voici mon problème

j'ai un dossier d'environ 400pdf qui portent déaj un nom

mon but est grace à une macro de chager le nom de ces 400 fichier automatiquement en fonction de 2 variables qui se trouve dans mon classeur excel

par ex

un fichier se nomme "\1234_docu.pdf"
et moi j'aimerais le renommer "1234_document.pdf"

1234 et document étant variables pour mes 400 fichiers?

Qu'en pensez vous??
Ajouter un commentaire
Réponse
-4
moins plus
en mettrant run.application("convertoPDF") ça marche
filoulebauju - 2 avril 2008 à 16:22
IL Y A ENCORE PLUS SIMPLE.

Tu enregistre une macro et pendant l'enregistrement, tu effectue ce que tu veux que ta macro fasse.
Ajouter un commentaire
Ce document intitulé « VBA macro pour convertir en pdf » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Passage au tout numérique : quel coût pour les particuliers ?