Excel数据批量写入Word
发布时间:2022-04-18 23:40:05
之前有两篇文章过Excel和Word数据交互的基础知识,这里说个实际遇到的综合案例,基本上将之前的知识点结合起来了。
一、实际案例引入
这次遇到的案例需求:将Excel数据批量写入Word。需要写入的内容如下图所示,红色框里的内容是需要写入word的。
我这里有很多个excel文件,每一个都需要打开把数据写入word。
写入之后的效果如下:
二、思路及代码
思路:循环打开Excel,先写订单号、厂款号、客款号。第二步需要通过find函数确定长款号表格的具体大小(为了将数据循环写入Word)。最后保存并关闭word。
具体代码如下:
Sub 提取数据()
Application.ScreenUpdating = False
Set doc = CreateObject(“word.application”)
doc.Visible = True
Set wd = doc.Documents.Add
pth = Application.GetOpenFilename(“文件(*.*),*.*”, , “请选择文件”, , True)
For i = 1 To UBound(pth) ‘循环打开选择的工作簿
Set wb = Workbooks.Open(pth(i)) ‘把打开的工作簿赋值给对象变量wb
strr = “订单号码” & wb.Worksheets(1).[b3] & vbTab & “客款号 ” & wb.Worksheets(1).[b5] & vbTab & “厂款号” & wb.Worksheets(1).[b6] ‘将需要写入的数据连接起来赋值给变量strr
doc.ActiveDocument.Content.InsertAfter Chr$(13) & strr ‘将订单编号、客款号、厂款号写入word
With wb.Worksheets(1)
col1 = .Columns(1).Find(“厂款号”, , xlValues, xlWhole, xlByColumns, xlNext, True, True).Row ‘定位厂款号跟合计字符,为了确定需要插入word文档中表格的大小
col2 = .Columns(1).Find(“合计”, , xlValues, xlWhole, xlByColumns, xlNext, True, True).Row
Set myrange = doc.ActiveDocument.Content
myrange.Collapse Direction:=wdCollapseEnd ‘折叠已经写入的内容
doc.Documents(1).Tables.Add myrange, col2 – col1, 11 ‘在word中插入新的表
doc.Documents(1).Tables(i).Style = “网格型” ‘表格类型是网格型
For r = col1 To col2 – 1
arr = .Range(“a” & r).EntireRow.Range(“a1:k1”) ‘循环将excel表中的数据写入word表格中
For Each ar In arr
n = n + 1 ‘将所在行的单元格值循环写入word表的单元格中
doc.Documents(1).Tables(i).Range.Cells(n).Range = ar
Next
Next
n = 0
End With
wb.Close False ‘数据写入完毕,关闭打开的工作簿’接着打开后面一个工作簿
Next
doc.Documents(1).SaveAs ThisWorkbook.Path & “\数据.docx” ‘将所有的工作簿循环打开,写入数据完毕,保存打开的word文档到代码工作簿路径下
doc.Quit ‘退出程序
Application.ScreenUpdating = True
End Sub
三、知识点
新建表格
代码中涉及到新建表格并写入数据的地方,这里给一个简单的例子作为参考。(这个代码直接在Word VBA中运行,如果需要在Excel中操作Word插入表格,需要新建Word程序对象,这属于前面的基础知识)
Sub 新建表格写入数据()
ActiveDocument.Tables(1).Delete
Set tb = ActiveDocument.Tables.Add(Selection.Range, 1, 3)
With tb
.Style = “网格型”
.Cell(1, 1).Range = “编号”
.Cell(1, 2).Range = “文件名”
.Cell(1, 3).Range = “扩展名”
.Rows.Last.Select
Selection.InsertRowsBelow 1
With .Rows.Last
.Cells(1).Range = 1
.Cells(2).Range = 2
.Cells(3).Range = 3
End With
End With
End Sub
代码运行效果如下:


猜你喜欢
- 在本月初,中国电信正式在广州、上海、南京、成都四座城市开通了 eSIM 一号双终端业务(适用于 Apple Watch Series 4、A
- 在网络时代快速发展的今天,越来越多的人不再满足于买书看小说了,而是开始使用小说阅读器,在网络上看小说了,小编就是其中一员,并且小编喜欢使用快
- Excel表格中发件人邮箱设置怎么设置?我们在企业中管理或者处理一些Excel数据的时候,都可以直接通过Excel表格来发送邮件给对方用户,
- win10时间预览版已经正式向大家推送,那么对于测试版而言,肯定会存在一些问题,下文小编就为大家带来win10手机预览版已知bug的汇总,小
- 关于录音质量好坏,噪声是一个非常大的因素,大部分情况下,录制的音频都会不可避免的出现噪音情况,这时候我们只能借助第三方软件来消除噪音,也就是
- 小编今天在win8系统在遇到了这样的情况,在超级管理员的帐号里面安装了apache环境,之后切换回管理员,就关机再也不能了,一直停留在正在关
- Word2010文件怎么只去除封面页码保留其他页码?word文件中想要除去封面页码,但是保留其它页码,该怎么设置呢?下面我们就来看看详细的教
- 在Finder边栏一般默认是不显示硬盘图标的,但我们可以通过Finder的偏好设置,让硬盘图标显示出来。下面分享Mac系统中如何在Finde
- 1.打开Word文档,点击工具栏的“插入”→“文本框”,接着我们就可以根据自己的需求选择文本框的类型。 2.插入文
- iphonexs开启半屏功能怎么操作?一只手玩手机时你会不会常感到不方便,根本够不到屏幕上方的APP,iphone很好的为大家考虑到这个问题
- PPT中插入表格,因为表格很难让人看懂,除非你的演讲能力超级棒,来弥补表格表达的不足。理想与现实总是有差距,职场中我们有时候不得不放表格在P
- excel表格怎么实现凑数求解?我们可以使用excel规划求解来实现,该怎么操作呢?下面我们就来看看简单的实例教程,需要的朋友可以参考下怎么
- 为了进一步方便管理资料,win11怎么分盘?这篇文章主要介绍了Win11电脑磁盘分盘方法,需要的朋友可以参考下Win11电脑磁盘分盘方法首先
- 爱剪辑是一款能够简单实用的视频剪辑工具,有很多的小伙伴都在使用,不过还有一部分刚接触的小伙伴不清楚如何使用爱剪辑快速剪辑视频,下面就和小编一
- 如果一段时间没有操作,黑屏之后再打开就得重新登录输入密码,尤其是设置了一些复杂密码或者图片密码的人,那可就麻烦了,下面与大家分享个比较实用的
- 不知从什么时候开始,曾经风靡全球的IE浏览器遭到了许多用户的嫌弃,甚至有些人选择了彻底弃用。当然,这与QQ浏览器、360浏览器、UC浏览器的
- 今日凌晨,苹果发布了 iOS 14.3 和 iPadOS 14.3 正式版更新,包括对 Apple Fitness+ 和 AIrPods M
- ppt怎么制作一个简单的红绿灯动画?ppt中想要制作一个红绿灯闪烁的动画,该怎么制作呢?下面我们就来看看ppt红绿灯动画的做法,需要的朋友可
- 在Word文档中有一个自动更正功能,通过该功能我们可以设置输入公司简称后自动转换为公司全称。那小伙伴们知道该怎么操作吗,其实操作步骤是非常简
- Win11图片密码怎么设置?win11系统中想要添加密码,该怎么添加图片密码呢?下面我们就来看看Win11开启图片密码的技巧Win11怎么设