我需要执行的步骤是重复的,但我不确定如何遍历每个工作簿,然后遍历每个工作表。Excel宏:遍历工作簿并打印每个工作簿中的单个工作表
我的任务是:
- 查找一个文件夹中(来源:文件夹)
- 迭代通过该文件夹(源文件),每个工作簿每4个工作表
- 打印(表名称)在每个工作簿中添加到PostScript打印机(打印机名称/路径)。
- 名称印刷到文件PS文件=源文件+表名称放置在最终的文件夹(目的地文件夹)
- 原始工作簿关闭,不保存
- 最后的PS输出文件。
我搜索了迭代VBA /宏,并看到了一些想法,但我不确定代码在工作簿和工作表中工作时的外观。
此外,PS打印机是通过打印到文件完成的。这是否会造成问题?
更新了代码,我已经试过到目前为止:
Sub Make_PS_Files()
Dim path2 As String, path3 As String
path2 = "Drive:\Source folder\"
path3 = " Drive:\Destination folder\"
Workbooks.Open Filename:=path2 + "File_Name.XLS"
Sheets("Specific_Sheet_Name1").Activate
Application.ActivePrinter = "\\PRINTER NAME\LOCATION:"
ActiveWindow.SelectedSheets.PrintOut copies:=1, PrintToFile:=True, Collate _
:=True, Prtofilename:=True
ActiveSheet.PrintOut copies:=1, Prtofilename:=path3 + " Specific_Sheet_Name1.ps"
Sheets("Specific_Sheet_Name2").Activate
Application.ActivePrinter = "\\VS PRINTER NAME\LOCATION:"
ActiveWindow.SelectedSheets.PrintOut copies:=1, PrintToFile:=True, Collate _
:=True, Prtofilename:=True
ActiveSheet.PrintOut copies:=1, Prtofilename:=path3 + " Specific_Sheet_Name2.ps"
Sheets("Specific_Sheet_Name3").Activate
Application.ActivePrinter = "\\ PRINTER NAME\LOCATION:"
ActiveWindow.SelectedSheets.PrintOut copies:=1, PrintToFile:=True, Collate _
:=True, Prtofilename:=True
ActiveSheet.PrintOut copies:=1, Prtofilename:=path3 + " Specific_Sheet_Name3.ps"
ActiveWorkbook.Close
Sheets("Specific_Sheet_Name4").Activate
Application.ActivePrinter = "\\ PRINTER NAME\LOCATION:"
ActiveWindow.SelectedSheets.PrintOut copies:=1, PrintToFile:=True, Collate _
:=True, Prtofilename:=True
ActiveSheet.PrintOut copies:=1, Prtofilename:=path3 + " Specific_Sheet_Name4.ps"
ActiveWorkbook.Close
End Sub
道歉时,我没有张贴这张贴昨晚。它在做什么似乎很长时间。我认为它可以更精细一点,所以它更通用,可以指向任何工作簿和任意数量的工作表。
并非所有工作表都具有Specific_Sheet_Name,所以我想遍历而不参考名称。
@Jmax:不要发布代码的道歉。我已经添加了上面的内容。 – RocketGoal
@Mike,你实际上是为每张纸使用不同的打印机吗?如果没有,那么你只需要设置'Application.ActivePrinter'一次。此外,在更改之前应先保存“ActivePrinter”的值,然后在完成后重置(或发生错误)。 –
@哈里。保存活动打印机的值?我通过录制宏来找到活动打印机的值,然后粘贴适当的值。你如何保存/重置它?为什么? – RocketGoal