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从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Python实现word文档内容智能提取以及合成

《Python实现word文档内容智能提取以及合成》这篇文章主要为大家详细介绍了如何使用Python实现从10个左右的docx文档中抽取内容,再调整语言风格后生成新的文档,感兴趣的小伙伴可以了解一下... 目录核心思路技术路径实现步骤阶段一:准备工作阶段二:内容提取 (python 脚本)阶段三:语言风格调

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient