VBA实例-从Excel整理数据到Word

实现目录

功能需求

1、将原始数据中不要的数据剔除

2、原始数据中增加序号、日期和时间三列数据,并且按报名类别进行分类。

3、形成时间表

4、将名称和类别复制到评分表中,一个名称一个word文档

5、将数据中的参数5和参数9复制到评分表中

数据结构

复制数据到新sheet并分类数据

bash 复制代码
If CheckIsExistsSheetName("时间表") Then
        ThisWorkbook.Sheets("时间表").Delete
    End If
    Application.DisplayAlerts = True
   For i = 2 To SumRows
        refValue = SourceSheet.Cells(i, 5) * 1
        If refValue > finalValue Then
            finalValue = refValue
        End If
   Next i
   For TargetDeviceSerialNumber = 1 To finalValue
        Set Gradeword = wdapp.Documents.Open(ThisWorkbook.Path & "\评分表.docx")
        Debug.Print Gradeword.Tables(1).Cell(3, 1).Range.Text
        Gradeword.Sentences(2).Characters(27) = EquipSectionsheet.Cells(TargetDeviceSerialNumber + 1, 3).Text 
        Gradeword.Sentences(2).Characters(8) = EquipSectionsheet.Cells(TargetDeviceSerialNumber + 1, 2).Text 
        jj = 3
        For j = 2 To SumRows
             refValue = SourceSheet.Cells(j, 5) * 1
             If refValue = TargetDeviceSerialNumber Then
                UseRows = UseRows + 1
                SourceSheet.Rows(j).Copy DestSheet.Cells(UseRows, 1)
                If IsEmpty(SourceSheet.Cells(j, 10)) Then
                    Gradeword.Tables(1).Cell(jj, 2).Range = SourceSheet.Cells(j, 14).Text
                Else
                    Gradeword.Tables(1).Cell(jj, 2).Range = SourceSheet.Cells(j, 10).Text
                End If
                jj = jj + 1
             End If
         Next j
        arr(TargetDeviceSerialNumber) = UseRows
        'Debug.Print'
        
        Gradeword.SaveAs2 (ThisWorkbook.Path + "\" + EquipSectionsheet.Cells(TargetDeviceSerialNumber + 1, 2).Text + "评分表" + "(" + EquipSectionsheet.Cells(TargetDeviceSerialNumber + 1, 3).Text + ")" + ".docx")
        Gradeword.Close
        Set Gradeword = Nothing
    Next TargetDeviceSerialNumber
    finalRows = UseRows
    DestSheet.Columns("A:D").Delete
    DestSheet.Range("C1").EntireColumn.Insert '序号
    DestSheet.Range("C1").EntireColumn.Insert '日期
    DestSheet.Range("C1").EntireColumn.Insert '时间
    DestSheet.Range("C1") = "序号"
    DestSheet.Range("D1") = "日期"
    DestSheet.Range("E1") = "时间"
    DestSheet.Cells(2, 5) = "9:00"
    
    For k = 2 To SumRows
        DestSheet.Cells(k, 3) = "=COUNT($C$1:C" & (k - 1) & ")+1"
    Next k
    
    For kk = 2 To SumRows - 1
        Day_mod = kk Mod (AM_ContrlRow + PM_ContrlRow)
        If Day_mod < AM_ContrlRow + 1 Then
            DestSheet.Cells(Day_mod + 1, 5) = "=TEXT(E" & kk & "+" & Chr(34) & "0:10" & Chr(34) & "," & Chr(34) & "h:mm" & Chr(34) & ")"
        ElseIf Day_mod = AM_ContrlRow + 1 Then
            DestSheet.Cells(Day_mod + 1, 5) = "14:00"
        Else
            DestSheet.Cells(Day_mod + 1, 5) = "=TEXT(E" & kk & "+" & Chr(34) & "0:10" & Chr(34) & "," & Chr(34) & "h:mm" & Chr(34) & ")"
        End If
    Next kk

添加序号、日期、时间三列数据

添加序号列

往单元格中添加公式"=COUNT(C1:C(k-1))+1"即可生成序号。

bash 复制代码
For k = 2 To SumRows
        DestSheet.Cells(k, 3) = "=COUNT($C$1:C" & (k - 1) & ")+1"
    Next k
添加时间列

往单元格中添加类似于"=TEXT(E2+"0:10","h:mm")"的公式,即可生成每隔10分钟的序列。

bash 复制代码
**For kk = 2 To SumRows - 1
        Day_mod = kk Mod (AM_ContrlRow + PM_ContrlRow)
        If Day_mod < AM_ContrlRow + 1 Then
            DestSheet.Cells(Day_mod + 1, 5) = "=TEXT(E" & kk & "+" & Chr(34) & "0:10" & Chr(34) & "," & Chr(34) & "h:mm" & Chr(34) & ")"
        ElseIf Day_mod = AM_ContrlRow + 1 Then
            DestSheet.Cells(Day_mod + 1, 5) = "14:00"
        Else
            DestSheet.Cells(Day_mod + 1, 5) = "=TEXT(E" & kk & "+" & Chr(34) & "0:10" & Chr(34) & "," & Chr(34) & "h:mm" & Chr(34) & ")"
        End If
    Next kk**

将名称和类别复制到word文件中

Gradeword.Sentences(2).Characters(27) = EquipSectionsheet.Cells(TargetDeviceSerialNumber + 1, 3).Text Gradeword.Sentences(2).Characters(8) = EquipSectionsheet.Cells(TargetDeviceSerialNumber + 1, 2).Text 这两句语句是将

中的名称和类别分别填写到对应的word文件档-----"评分表.docx"中名称和类别处

即:

将参数5和参数9中的一个复制到word文件中

将参数5和参数9中的一个复现到 "评分表.docx"中参数5/参数9这列中

bash 复制代码
If IsEmpty(SourceSheet.Cells(j, 10)) Then
                    Gradeword.Tables(1).Cell(jj, 2).Range = SourceSheet.Cells(j, 14).Text
                Else
                    Gradeword.Tables(1).Cell(jj, 2).Range = SourceSheet.Cells(j, 10).Text
                End If
                jj = jj + 1

实例

实例

相关推荐
开开心心就好4 小时前
一款既是直播工具又是浏览器的软件
linux·运维·服务器·智能手机·逻辑回归·excel·最小二乘法
第五文修5 小时前
wps表格内编写一个JSA宏用来背单词
excel·wps
小脑斧1236 小时前
DBExport2.51 Oracle数据库查询与Excel数据导出工具
数据库·oracle·excel
努力成为大牛吧6 小时前
Word/WPS 论文参考文献排版及交叉引用注意事项
word·wps
开开心心_Every6 小时前
跨平台高速下载工具,支持浏览器功能强大
运维·服务器·随机森林·pdf·电脑·逻辑回归·excel
qq_283720057 小时前
Python3 模块精讲|python-docx 万字实战:全自动读写 Word 文档,办公效率直接翻倍
python·自动化·word
gc_22997 小时前
学习C#调用OpenXml操作word文档的基本用法(26:学习文本运行类)
word·openxml·run
AC赳赳老秦21 小时前
OpenClaw权限管理实操:团队共享Agent,设置操作权限,保障数据安全
服务器·开发语言·前端·javascript·excel·deepseek·openclaw
Teable任意门互动1 天前
多维表格哪家最好用最容易上手?国产开源 Teable 测评
开发语言·数据库·开源·excel·飞书·开源软件
wtsolutions1 天前
Excel-to-JSON Local App - Secure Offline Excel to JSON Conversion
json·excel