VBA实现word文档批量转PDF文件

word批量转PDF文件,只需要修改路径即可!

vbnet 复制代码
Option Explicit

Sub wordtoPDF()
    Dim folderPath As String
    
    Dim outputFolder As String
    
    Dim fileName As String
    
    Dim doc As Document
    
    Dim fileSaved As Boolean
    
    ' 关闭屏幕刷新,提升性能
    Application.ScreenUpdating = False
    
    ' 设置输入和输出文件夹路径(只需修改这里)
'    folderPath = "C:\Users\YourName\Docs\WordFiles\" ' Word 文件所在文件夹
'    outputFolder = "C:\Users\YourName\Docs\PDFFiles\" ' PDF 保存文件夹
    
    folderPath = "D:\exceldata\VBA_word\word\" ' Word 文件所在文件夹
    outputFolder = "D:\exceldata\VBA_word\word\" ' PDF 保存文件夹
    
    ' 检查输出文件夹是否存在,不存在则创建
    If Dir(outputFolder, vbDirectory) = "" Then
        MkDir outputFolder
    End If
     
    ' 遍历文件夹中的 Word 文件
    fileName = Dir(folderPath & "*.docx")
    
    'Debug.Print fileName
    While fileName <> ""
        ' 打开当前 Word 文档
        Set doc = Documents.Open(folderPath & fileName)
        
        ' 生成对应的 PDF 文件路径
        Dim pdfFileName As String
        pdfFileName = outputFolder & Replace(fileName, ".docx", ".pdf")
        
        ' 将文档另存为 PDF 格式
        doc.SaveAs2 pdfFileName, FileFormat:=wdFormatPDF
        
'        If fileSaved Then
'            doc.Saved = True
'        End If
        
        ' 关闭文档,释放内存
        'doc.Close
        'doc.Close savechanges:=wdDoNotSaveChanges
        doc.Close savechanges:=wdSaveChanges
        ' 获取下一个 Word 文件
        fileName = Dir()
    Wend
    ' 恢复屏幕刷新
    Application.ScreenUpdating = True
    ' 提示转换完成
    MsgBox "批量转换完成!请检查 PDF 文件夹。"
End Sub

只转当前活动的word文档为PDF,不是批量化操作

vbnet 复制代码
Option Explicit

Sub SaveActiveDocumentToPDF()
    Dim pdfPath As String
    
    ' 生成PDF文件路径:与原文档同路径,仅修改扩展名
    pdfPath = Replace(ActiveDocument.FullName, ".docx", ".pdf")
    ' 如果是.doc格式的文档,可使用下面这行代码
    ' pdfPath = Replace(ActiveDocument.FullName, ".doc", ".pdf")
    
    ' 导出为PDF
    ActiveDocument.ExportAsFixedFormat _
        OutputFileName:=pdfPath, _
        ExportFormat:=wdExportFormatPDF, _
        OpenAfterExport:=True ' 设置为True可在导出后自动打开PDF
        
        
    '获取原文档路径: ActiveDocument.FullName 用于获取当前文档的完整路径和文件名?
    '
    '构造PDF路径:使用 Replace 函数将原文件扩展名(如".docx")替换为".pdf"。
    '
    '导出PDF:ExportAsFixedFormat 是核心方法,参数 wdExportFormatPDF 表示导出格式为PDF
    '
    '
    '导出后操作:将 OpenAfterExport 设置为 True,导出后会自动打开PDF文件。
    
End Sub

wdExportFormatPD和wdFormatPDF的区别

特性维度 wdExportFormatPDF wdFormatPDF
主要用途 通过ExportAsFixedFormat方法导出为PDF 通过SaveAsSaveAs2方法另存为PDF
所属方法 ExportAsFixedFormat SaveAs2
功能特点 提供更精细的PDF输出控制,如导出范围、图像质量优化、书签处理等 主要用于指定文件格式,PDF相关的高级选项支持可能有限
相关推荐
mudtools3 分钟前
存储那么贵,何不白嫖飞书云文件空间
前端框架·c#·.net
其实秋天的枫31 分钟前
【26年3月最新】计算机二级WPS真题试题及答案14套电子版PDF(含操作题和选择题)
经验分享·pdf
DeskUI~~40 分钟前
倚天剑术34--批量获取PDF文档中的图片
pdf
河北之花41 分钟前
演示软件界面及快捷键、幻灯片操作、输出为PDF
pdf·wps
我是唐青枫43 分钟前
C#.NET SignalR + Redis Backplane 深入解析:多节点部署与跨实例消息同步
c#·.net
星河Cynthia1 小时前
WPF基于resx资源文件的多语言实现
c#·wpf
量子物理学1 小时前
WPF 标签预览可以显示图片运行后不显示
c#·wpf
开开心心就好2 小时前
安卓免费证件照制作软件,无广告弹窗
linux·运维·安全·pdf·迭代器模式·依赖倒置原则·1024程序员节
格林威2 小时前
工业相机图像采集处理:从 RAW 数据到 AI 可读图像,海康相机 C# 实战代码深度解析
开发语言·c++·人工智能·数码相机·c#·工业相机·堡盟相机
萝卜白菜。2 小时前
TongWeb7.0配置tongweb-web.xml修改jsessionid名及其值的长度
xml·前端·word