VBA macro pour convertir en pdf

Fermé
Canard007 Messages postés 5929 Date d'inscription mercredi 26 mai 2004 Statut Contributeur Dernière intervention 18 septembre 2009 - 4 janv. 2005 à 14:43
 belanf - 25 mars 2017 à 19:25
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!
A voir également:

6 réponses

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
27
merci pour ce raccourci qui fonctionne !
Mais comment restreindre à la zone d'impression plutot que de convertir la totalité des feuilles ?
Par exemple, j'ai des feuilles avec un menu déroulant identique sur la droite et je ne veut imprimer que la zone sur la gauche ?
0
2xpi Messages postés 1 Date d'inscription mardi 2 février 2010 Statut Membre Dernière intervention 2 février 2010
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
0
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
0
Juste un grand merci!
0
Bonjour le code fonctionne bien
Mais comment faire pour convertir quelques feuilles au lieu de tout le classeur.
D'avance merci
0
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
0
WhiteFang Messages postés 2063 Date d'inscription dimanche 1 septembre 2002 Statut Membre Dernière intervention 15 février 2008 204
5 janv. 2005 à 06:11
;-)

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
-1
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
0
blux Messages postés 26498 Date d'inscription dimanche 26 août 2001 Statut Modérateur Dernière intervention 28 novembre 2024 3 317
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 ?
0
Nyarta > blux Messages postés 26498 Date d'inscription dimanche 26 août 2001 Statut Modérateur Dernière intervention 28 novembre 2024
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.
0
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
-2

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
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??
-2
snejena Messages postés 1 Date d'inscription mardi 3 mai 2005 Statut Membre Dernière intervention 18 août 2006
18 août 2006 à 15:03
en mettrant run.application("convertoPDF") ça marche
-5
IL Y A ENCORE PLUS SIMPLE.

Tu enregistre une macro et pendant l'enregistrement, tu effectue ce que tu veux que ta macro fasse.
0