Solved

Creating a macro in Excel 2007 to auto repeat rows, except the last page, and send to pdf instead of print.

Posted on 2013-01-10
5
921 Views
Last Modified: 2013-02-04
I got this code from another EE answer. Playing with it, and not sure I understand the line marked with **.  

ALSO, the macro works, but not exactly what I'm looking for.  It does the auto repeat rows in Excel and allows me to change the auto repeat rows for the last page correctly.   BUT, I want to create a .pdf when I run the macro instead of sending out a print job.  

How can I tweak to make this happen.    Code follows:


Sub PrintTest()
'macro written by nutsch on 4/23/08, with lots of inspiration from http://www.rondebruin.nl/print.htm
Dim TotPages As Long
**TotPages = application.ExecuteExcel4Macro("GET.DOCUMENT(50)")
 
With ActiveSheet
    .PageSetup.PrintTitleRows = "$1:$7"
    .PrintOut From:=1, To:=TotPages - 1
    .PageSetup.PrintTitleRows = "$1:$6"
    .PrintOut From:=TotPages, To:=TotPages
End With
 
End Sub
0
Comment
Question by:InfoChase
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
5 Comments
 
LVL 31

Expert Comment

by:gowflow
ID: 38766258
Well here it is:
TotPages = Application.ExecuteExcel4Macro("GET.DOCUMENT(50)")
Will return in the variable TotPages the number of pages to be printed.

As far as creating a .pdf question is: on your pc how do you create a .pdf do you use pdf995 as printer and print to it and then it create the pdf or ... ? based on your answer will advise next step.
gowflow
0
 
LVL 31

Accepted Solution

by:
gowflow earned 500 total points
ID: 38766837
The following code will create a pdf file as distiller from the activesheet in excel. You may change the printer name to the adobe printer you have on your pc.

Sub Test_dist_PDF()
Dim PSFileName As String
Dim PDFFileName As String
PSFileName = "c:\myPostScript.ps"
PDFFileName = "c:\myPDF.pdf"

' Print the Excel range to the postscript file
Dim MySheet As Worksheet
Set MySheet = ActiveSheet
MySheet.UsedRange.PrintOut copies:=1, preview:=False, ActivePrinter:="PDF995", printtofile:=True, collate:=True, PrToFileName:=PSFileName

' Convert the postscript file to .pdf
Dim myPDF As PdfDistiller
Set myPDF = New PdfDistiller
myPDF.FileToPDF PSFileName, PDFFileName, ""
myPDF.Create

End Sub

Open in new window



Let me know.
gowflow
0
 
LVL 31

Expert Comment

by:gowflow
ID: 38848685
Did you hv a chance to try the proposed solution ?
gowflow
0
 

Author Comment

by:InfoChase
ID: 38851853
The code worked, but not exactly what I needed. The situational need has passed, and I do not need to pursue this issue any further.  Thanks for the assist; the code, and the idea, may be useful for some other situation down the road.
0
 
LVL 31

Expert Comment

by:gowflow
ID: 38851985
Your welcome, let me put a samll comment here. You may not need the code now as you mentioned 'The situational need has passed' and it is understood however this does not remove the fact that it was a total working solution as it happens that I use this specific code in my software developped to clients. Furthermore you confirmed that the solution worked (but it was not exactly what you needed)

All this being said, do you feel that it is fair that you rated this question B ?

gowflow
0

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article will guide you to convert a grid from a picture into Excel format using Microsoft OneNote and no other 3rd party application.
This article describes a serious pitfall that can happen when deleting shapes using VBA.
This Micro Tutorial will demonstrate in Google Sheets how to use the HYPERLINK function to create live links inside your spreadsheet.
Although Jacob Bernoulli (1654-1705) has been credited as the creator of "Binomial Distribution Table", Gottfried Leibniz (1646-1716) did his dissertation on the subject in 1666; Leibniz you may recall is the co-inventor of "Calculus" and beat Isaac…

623 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question