VBA的excel逐行替换到word模板及打印还原

滥竽充数砖家,有量没有质的罗列...

vbscript 复制代码
Option Explicit
' 需要在工具->引用库中找到Microsoft word x.xx library勾选上。

Sub ReplaceAndPrint()

    Dim WrkSht As Worksheet
    Set WrkSht = ActiveSheet
    
    Dim RowNumber As Integer
    Dim ColNumber As Integer
    RowNumber = WrkSht.Range("A1").CurrentRegion.Rows.Count
    ColNumber = WrkSht.Range("A1").CurrentRegion.Columns.Count
    
    Dim wordApp As Object
    Dim wordDoc As Object
    Dim excelPath As String
    Dim wordFilePath As String
    Dim j As Integer
    Dim k As Integer
    Dim i As Integer
    Dim colSate As Long, colSime As Long, colLocation As Long, colNumc As Long '用来定位指定列
    ' 查找列位置
    colSate = 0: colSime = 0: colLocation = 0: colNumc = 0
    
    For j = 1 To ColNumber
        Select Case WrkSht.Cells(1, j).Value '第一行的列名循环
            Case "Sate"
                colSate = j
            Case "Sime"
                colSime = j
            Case "Queue Number"
                colLocation = j
            Case "Number"
                colNumc = j
        End Select
    Next j
       
    
    ' 定义替换对照表
    Dim originWords() As String
    Dim replaceWords() As String
    
    ReDim originWords(1 To 4)
    ReDim replaceWords(1 To 4)
    
    originWords(1) = "dd/mm/yyyy"
    originWords(2) = "hh:ss"
    originWords(3) = "queque"
    originWords(4) = "01-B-2111240011"
    
    replaceWords(1) = "pp/pp/mmmm"
    replaceWords(2) = "zz:yy"
    replaceWords(3) = "yueyue"
    replaceWords(4) = "01-B-2111240088"
    

    ' 获取文件路径
    excelPath = ThisWorkbook.Path
    wordFilePath = excelPath & "\猪脚饭1.docx"
    
    ' 检查文件是否存在
    If Dir(wordFilePath) = "" Then
        MsgBox "未找到Word文件:" & wordFilePath
        Exit Sub
    End If
    
    
    ' 创建Word应用
    Set wordApp = CreateObject("Word.Application")
    wordApp.Visible = True
    
    ' 打开文档
    Set wordDoc = wordApp.Documents.Open(wordFilePath)
    ' 指定打印机
    wordApp.ActivePrinter = "POS80"
    
    ' 一行一行循环替换所有关键词,并打印。
    For k = 2 To RowNumber
        replaceWords(1) = WrkSht.Cells(k, colSate).Value
        replaceWords(2) = WrkSht.Cells(k, colSime).Value
        replaceWords(3) = WrkSht.Cells(k, colLocation).Value
        replaceWords(4) = WrkSht.Cells(k, colNumc).Value
        For i = 1 To UBound(originWords)
            With wordDoc.Range.Find
                .ClearFormatting
                .Replacement.ClearFormatting
                .Text = originWords(i)
                .Replacement.Text = replaceWords(i)
                .Forward = True
                .Wrap = 1
                .Format = False
                .MatchCase = False
                .MatchWholeWord = False
                .Execute Replace:=2
            End With
        Next i
        ' 打印步骤在此,打印完后word模板还原。
        wordDoc.PrintOut
        Application.Wait Now + TimeValue("0:00:01")
        wordDoc.Undo Times:=4  ' 撤销4步
    Next k

End Sub
相关推荐
野比带雄3 小时前
対excel时间格式的理解
excel
缺点内向4 小时前
Java:轻松实现 Excel 文档属性添加
java·开发语言·excel
Teable任意门互动7 小时前
从飞书多维表格 简道云到Teable多维表格:企业为何选择Teable作为新一代智能数据协作平台?
数据库·excel·钉钉·飞书·开源软件
AC赳赳老秦9 小时前
DeepSeek + Excel 实战:多表联动分析与异常数据自动预警教程
microsoft·rabbitmq·excel·etcd·memcached·memcache·deepseek
2501_930707789 小时前
如何使用C#代码将 Excel 文件转换为 SVG
开发语言·c#·excel
Eiceblue11 小时前
将 Python 列表导出为 Excel 文件:一维、二维、字典列表
开发语言·python·excel·visual studio code
Shi_haoliu1 天前
inno setup6.6.1实例,制作安装包,创建共享文件夹,写入注册表(提供给excel加载项,此文章解释iss文件)
前端·vue.js·windows·excel
2501_907136821 天前
通用财务账模板【Excel版】
excel·软件需求
CodeCraft Studio1 天前
Excel处理控件Aspose.Cells教程:使用C#在Excel中创建折线图
java·c#·excel·aspose.cells·excel图表·excel api库·excel折线图
狼与自由1 天前
excel 导入 科学计数法问题处理
java·前端·excel