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

相关文章

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt