word批量导出visio图

具体步骤

修改word格式

将word文档修改为docm格式

打开VBA窗口

打开开发工具VisualBasic项,如果没有右键在自定义功能区添加

插入代码

插入 -> 模块,代码如下:

vba 复制代码
Sub ExportAllVisioDiagrams()
    Dim shp As InlineShape
    Dim i As Integer
    Dim savePath As String
    Dim docName As String
    Dim visioApp As Object
    Dim visioDoc As Object
    Dim startTime As Double
    
    ' 设置保存路径(修改为您想要的路径)
    savePath = "C:\Users\"
    
    ' 创建文件夹(如果不存在)
    If Dir(savePath, vbDirectory) = "" Then MkDir savePath
    
    ' 获取文档名称(不含扩展名)
    If ActiveDocument.Name Like "*.*" Then
        docName = Left(ActiveDocument.Name, InStrRev(ActiveDocument.Name, ".") - 1)
    Else
        docName = ActiveDocument.Name
    End If
    
    ' 创建Visio应用实例
    Set visioApp = CreateObject("Visio.Application")
    visioApp.Visible = True ' 设置为可见以便调试
    
    i = 1
    For Each shp In ActiveDocument.InlineShapes
        If shp.Type = wdInlineShapeEmbeddedOLEObject Then
            If InStr(1, shp.OLEFormat.ProgID, "Visio", vbTextCompare) > 0 Then
                On Error Resume Next
                
                ' 激活并选择Visio对象内容
                shp.OLEFormat.Activate
                shp.OLEFormat.Object.Application.ActiveWindow.SelectAll
                shp.OLEFormat.Object.Application.ActiveWindow.Selection.Copy
                
                ' 创建新Visio文档
                Set visioDoc = visioApp.Documents.Add("")
                
                ' 添加延迟确保复制完成
                startTime = Timer
                Do While Timer < startTime + 1
                    DoEvents
                Loop
                
                ' 粘贴内容
                visioApp.ActiveWindow.Page.Paste
                
                ' 保存文件
                visioDoc.SaveAs savePath & docName & "_Diagram" & i & ".vsdx"
                If Err.Number <> 0 Then
                    visioDoc.SaveAs savePath & docName & "_Diagram" & i & ".vsd"
                End If
                
                visioDoc.Close
                Set visioDoc = Nothing
                
                i = i + 1
                
                ' 每处理3个图表后增加延迟
                If i Mod 3 = 0 Then
                    startTime = Timer
                    Do While Timer < startTime + 2 ' 延迟2秒
                        DoEvents
                    Loop
                End If
                
                On Error GoTo 0
            End If
        End If
    Next shp
    
    ' 关闭Visio
    visioApp.Quit
    Set visioApp = Nothing
    
    MsgBox "已导出 " & (i - 1) & " 个Visio图表到 " & savePath
End Sub

运行代码

点击运行 -> 运行子过程即可

相关推荐
我材不敲代码2 小时前
Python实现打包贪吃蛇游戏
开发语言·python·游戏
身如柳絮随风扬3 小时前
Java中的CAS机制详解
java·开发语言
韩立学长4 小时前
【开题答辩实录分享】以《基于Python的大学超市仓储信息管理系统的设计与实现》为例进行选题答辩实录分享
开发语言·python
froginwe115 小时前
Scala 循环
开发语言
m0_706653235 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你915 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
Bruk.Liu5 小时前
(LangChain实战2):LangChain消息(message)的使用
开发语言·langchain
qq_423233905 小时前
C++与Python混合编程实战
开发语言·c++·算法
m0_715575345 小时前
分布式任务调度系统
开发语言·c++·算法
PfCoder6 小时前
C#中定时器之System.Timers.Timer
c#·.net·visual studio·winform