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

实例

实例

相关推荐
bing_1582 小时前
Excel 如何进行多条件查找或求和?
excel
秀儿还能再秀2 小时前
基于Excel的数据分析思维与分析方法
数据分析·excel
bing_1582 小时前
Excel 如何处理更复杂的嵌套逻辑判断?
excel
weixin_472339462 小时前
高效处理大体积Excel文件的Java技术方案解析
java·开发语言·excel
灵犀学长2 小时前
EasyExcel之SheetWriteHandler:解锁Excel写入的高阶玩法
spring boot·excel
全干engineer14 小时前
Spring Boot 实现主表+明细表 Excel 导出(EasyPOI 实战)
java·spring boot·后端·excel·easypoi·excel导出
Fireworkitte14 小时前
Java 中导出包含多个 Sheet 的 Excel 文件
java·开发语言·excel
wh393320 小时前
使用Python将PDF转换成word、PPT
python·pdf·word
chemddd20 小时前
excel 工作需要会的
excel
醇氧1 天前
【wps】 excel 删除重复项
excel·wps