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

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum