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

使用VBA宏在Excel中批量将xlsx文件夹内的所有表格文件转换为PDF,支持多个工作表的逐一转换,适用于自动化办公场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

可以在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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值