EXCEL VBA根据数据生成word文档周报并加背景格式突出显示

本文主要是介绍EXCEL VBA根据数据生成word文档周报并加背景格式突出显示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

EXCEL VBA根据数据生成word文档周报并加背景格式突出显示

Public wwSub 生成word()Dim ww As WorksheetDim wj As WorksheetDim wz As WorksheetDim wb As WorkbookDim wbf As Workbookfpath = ThisWorkbook.Path & "\"fname = Dir(fpath)hz_str = ""Do While fname <> ""If fname <> ThisWorkbook.Name ThenSet wbf = Workbooks.Open(fpath & fname)Set ww = wbf.Worksheets("文档")Set wj = wbf.Worksheets("金额")Set wz = wbf.Worksheets("周报")For i = 2 To ww.Range("a" & ww.Cells.Rows.Count).End(xlUp).RowIf ww.Cells(i, 4) <> "" Thenhz_str = hz_str & "● 【" & ww.Cells(i, 3) & "】" & ww.Cells(i, 2) & " " _& ww.Cells(i, 4) & Chr(10)End IfNextEnd Iffname = DirLoopwz.Cells(4, 6) = wj.Range("d" & wj.Range("d" & wj.Cells.Rows.Count).End(xlUp).Row)wz.Cells(6, 2) = Left(hz_str, Len(hz_str) - 1)wz.Cells(4, 3) = wj.Range("c" & wj.Range("c" & wj.Cells.Rows.Count).End(xlUp).Row)If wz.Cells(4, 3) = 0 Thenwz.Range("b4:d4").Clearwz.Cells(4, 3) = "测算无数据"Elsewz.Cells(4, "b") = "测算共计"wz.Cells(4, "d") = "笔,"End IfDim WordApp As ObjectSet WordApp = CreateObject("Word.Application")WordApp.Visible = TrueDim WordD As ObjectSet WordD = WordApp.Documents.AddSet wdTable = WordD.Tables.Add(WordD.Range, 1, 1)With wdTable.Borders.Item(1).LineStyle = 0 ' 去掉上边框.Item(4).LineStyle = 0  ' 去掉左边框.Item(2).LineStyle = 0  ' 去掉右边框With .Item(3)           ' 设置底部边框.LineStyle = 1      ' 实线.LineWidth = 12    ' 1.5磅End WithEnd WithWith wdTable.cell(1, 1).Range.Text = "周报".Font.Name = "微软雅黑" ' 设置字体.Font.Size = 20.Font.Bold = True.ParagraphFormat.SpaceAfter = 8 ' 设置段后间距为8.ParagraphFormat.LineSpacingRule = 5.ParagraphFormat.Alignment = 1End WithSet rng = WordD.Rangerng.Collapse Direction:=0  ' 将Range对象的起始位置移动到当前光标位置rng.InsertAfter vbCrLf     ' 插入一个空行Set paragraphRange = WordD.Paragraphs(3).RangeWith paragraphRange.Font.Name = "宋体 (中文正文)"        ' 设置字体为Calibri.Size = 10               ' 设置字体大小为14End WithIf wz.Cells(4, 3) = "测算无数据" Thenrng.InsertAfter "测算无数据" & vbCrLfElserng.InsertAfter "测算共计" & wz.Cells(4, 3) & "笔, 合计金额" & _wz.Cells(4, 6) & "万元。" & vbCrLfEnd IfSet paragraphRange = WordD.Paragraphs(4).RangeWith paragraphRange.Font.Name = "宋体"        ' 设置字体为Calibri.Size = 16               ' 设置字体大小为14End With' 添加空行Set paragraphRange = WordD.Paragraphs(5).RangeWith paragraphRange.Font.Name = "宋体 (中文正文)"        ' 设置字体为Calibri.Size = 10.5               'End Withrng.InsertAfter vbCrLfrng.InsertAfter "政府工程" & vbCrLfSet paragraphRange = WordD.Paragraphs(6).RangeWith paragraphRange.Font.Name = "宋体 (中文正文)"        ' 设置字体为Calibri.Size = 10.5End Withfen_hz_str = Split(hz_str, Chr(10))For i = 0 To UBound(fen_hz_str) - 1xx = i + 1 & "." & Right(fen_hz_str(i), Len(fen_hz_str(i)) - 1)rng.InsertAfter xx & vbCrLfSet paragraphRange = WordD.Paragraphs(6).RangeWith paragraphRange.Font.Name = "宋体 (中文正文)"        ' 设置字体为Calibri.Size = 10End WithNext'    Set myrange = WordD.Content
'    myrange.Collapse Direction:=wdCollapseEnd
'    Set wdTable = WordD.Tables.Add(myrange, 1, 1)
'    For i = 0 To UBound(fen_hz_str) - 1
'        x = x & Chr(11) & i + 1 & "." & Right(fen_hz_str(i), Len(fen_hz_str(i)) - 1)
'    Next
'
'    With wdTable.cell(1, 1).Range
'        .Text = Right(x, Len(x) - 1)
'        .Font.Name = "宋体" ' 设置字体
'        .Font.Size = 9
'        .ParagraphFormat.SpaceAfter = 8 ' 设置段后间距为8磅
'        .ParagraphFormat.LineSpacingRule = 5
'    End With
'Set rng = WordD.Rangerng.Collapse Direction:=0  ' 将Range对象的起始位置移动到当前光标位置rng.InsertAfter vbCrLf     ' 插入一个空行'.CopyPicture是可以作为图片复制的With WordD.Content.Collapse Direction:=0 ' Collapse to the end of the documentwjstrow = wj.Range("a1").End(xlDown).Rowwj.Range("a" & wjstrow & ":d" & wj.Range("d" & wj.Cells.Rows.Count).End(xlUp).Row).Copy ' 复制Excel表格.PasteExcelTable False, False, TrueEnd WithSet tbl = WordD.Tables(WordD.Tables.Count).Rows(1).Rangetbl.Shading.Texture = wdTextureNonetbl.Shading.BackgroundPatternColor = RGB(211, 211, 211)Set tbl = WordD.Tables(WordD.Tables.Count)For Each col In tbl.Columnscol.Width = 110Next coltbl.AutoFitBehavior wdAutoFitWindowFor Each rw In tbl.Rowsrw.Height = 25Next'''''''Application.DisplayAlerts = Falsewbf.CloseApplication.DisplayAlerts = TrueWordD.SaveAs ThisWorkbook.Path & "\周报.docx"WordD.CloseWordApp.QuitCall 模块2.HightLightEnd Sub

模块2.HightLight

Sub HightLight()Dim objWord As ObjectDim objDocSet objWord = CreateObject("Word.Application")
'    Set objWord = GetObject(, "Word.Application")objWord.Visible = TrueSet objDoc = objWord.Documents.Open(ThisWorkbook.Path & "\周报.docx")objWord.Selection.Find.ClearFormattingobjWord.Selection.Find.Replacement.ClearFormattingobjWord.Selection.Find.Replacement.Highlight = TrueWith objWord.Selection.Find.Text = "【*】".Replacement.Text = "".Forward = True.Wrap = 0.Format = True.MatchCase = False.MatchWholeWord = False.MatchByte = False.MatchAllWordForms = False.MatchSoundsLike = False.MatchWildcards = TrueEnd WithobjWord.Selection.Find.Execute Replace:=2objDoc.SaveobjDoc.CloseobjWord.QuitSet objDoc = NothingSet objWord = NothingMsgBox "done"
End Sub

这篇关于EXCEL VBA根据数据生成word文档周报并加背景格式突出显示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1115121

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式

《C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式》Markdown凭借简洁的语法、优良的可读性,以及对版本控制系统的高度兼容性,逐渐成为最受欢迎的文档格式... 目录为什么要将文档转换为 Markdown 格式使用工具将 Word 文档转换为 Markdown(.

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据