Excel VBA 批量转换文件夹下的xlsx文件为pdf(多文件多sheet)

可以在excel工作表中通过宏将一个文件夹中的所有xlsx或类似的表格文件批量转换为pdf文件,遍历每个工作表的每个sheet并逐一转换。

Sub TO_PDF()

On Error Resume Next
Dim ALL_FILE As String, SourcePath As String, NewSaveFile As String
Dim CurFile As Object
Dim shit As Worksheet

SourcePath = "D:\WORK\" 
'待转换的源xlsx文件夹路径
OBJPath = "D:\WORK\PDF\"
'转换为pdf文件后的存放路径

ALL_FILE = Dir(SourcePath & "*.xlsx")'用*.xls*匹配其他xls、xlsm格式文件
Do While ALL_FILE <> ""
   Set CurFile = Workbooks.Open(SourcePath & ALL_FILE, , msoTrue)
   
   '遍历每个xlsx文件中的每个sheet进行转换
   For Each shit In CurFile.Worksheets
   NewSaveFile = OBJPath & "\" & CurFile.Name & "--" & shit.Name & ".pdf"
   '设置pdf文件名称
   shit.ExportAsFixedFormat Type:=xlTypePDF, Filename:=NewSaveFile
   '依次转换
   Next
  
   CurFile.Close SaveChanges:=False
   ALL_FILE = Dir
Loop
Set CurFile = Nothing

End Sub

其他xls、xlsm、csv格式文件转txt或pdf等相关方法参考以下内容:
https://blog.csdn.net/goldengod/article/details/79226612
VBA基础教程
参考:https://blog.csdn.net/pijianzhirui/article/details/85939896

  • 3
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
VBA是Visual Basic for Applications的缩写,用于微软Office项目的编程语言。VBA开发人员可以编写VBA代码来自动完成复杂任务,可以大大提高工作效率。在日常工作中,我们常常需要将Excel文件转换PDF格式,以便在不同平台上共享和传递。手动将每个Excel文件转换PDF格式是非常繁琐的,因此使用VBAExcel文件批量转换PDF格式是非常有用的。 使用VBA批量转换Excel文件PDF的主要步骤如下: 1.打开需要转换Excel文件所在的目录。 2.遍历目录中的每个Excel文件,使用VBA代码将其转换PDF格式。 3.保存转换后的PDF文件。 在这个过程中,需要使用VBA文件操作和打印功能。文件操作需要使用FileSystemObject或Dir函数。打印功能可以使用PrintOut方法或PdfCreator等第三方库。 以下是一个简单的VBA代码示例,演示如何批量Excel文件转换PDF。代码中假设所有的Excel文件都保存在同一个文件夹中。 Sub ConvertToPDF() Dim myPath As String Dim myFile As String Dim Wb As Workbook '指定文件夹的路径 myPath = "C:\Users\MyFolder\" '获取文件夹中的第一个文件名 myFile = Dir(myPath & "*.xlsx") '遍历所有文件 Do While myFile <> "" '打开工作簿 Set Wb = Workbooks.Open(myPath & myFile) '将工作簿另存为PDF文件 Wb.ExportAsFixedFormat Type:=xlTypePDF, Filename:= _ myPath & Replace(myFile, ".xlsx", ".pdf"), Quality:=xlQualityStandard, _ IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:=False '关闭工作簿 Wb.Close SaveChanges:=False '获取文件夹中的下一个文件名 myFile = Dir Loop End Sub 这个VBA代码示例非常简单,只是将Excel文件转换PDF格式并保存在同一个文件夹中。但是,根据具体需求,可以进一步优化代码以满足不同的转换需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值