ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 21152|回复: 69

[原创] Excel与Word数据交互【带案例】

  [复制链接]

TA的精华主题

TA的得分主题

发表于 2019-11-6 13:02 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 梧叶沙沙 于 2019-11-6 13:08 编辑


自己遇到的一些实际例子,分享给大家。很多代码也是从论坛学习来的。


例子很基础,希望能抛砖引玉





主要涉及以下几个方面:

Excel与Word表格交互读取
Excel与Word图片的交互(批量导出Word图片)
Excel批量生成Word合同







Word VBA中的常用对象及一些常用代码:



image.png





①Excel读取Word数据的框架:

  1. Sub 打开Word()
  2.     Set doc = CreateObject("word.application")
  3.     f = Dir(ThisWorkbook.Path & "\*.doc")
  4.     Do While f <> ""
  5.         Set wd = doc.documents.Open(ThisWorkbook.Path & "" & f)
  6.         doc.Visible = True
  7.        '对Word进行操作的具体数据
  8.         f = Dir
  9.         wd.Close False
  10.     Loop
  11.     doc.Quit
  12.     MsgBox "完成!"
  13. End Sub
复制代码



②Word VBA向word表格写数据:

如下图所示的数据,如果要用WordVBA写入数据,有两种方式。

image.png

  1. Sub 第一种写入方法()
  2.     Dim t As Table
  3.         Set t = ActiveDocument.Tables(1)
  4.         t.Cell(1, 1).Range = 1
  5.         t.Cell(1, 2).Range = 2
  6.         t.Cell(1, 3).Range = 3
  7.         t.Cell(2, 1).Range = 4
  8.         t.Cell(2, 2).Range = 5
  9.         t.Cell(2, 3).Range = 6
  10. End Sub


  11. Sub 第二种写入方法()
  12.     Set t = ActiveDocument.Tables(1).Range
  13.     For i = 1 To t.Cells.Count
  14.         t.Cells(i).Range = i
  15.     Next
  16. End Sub
复制代码




③Word VBA新建2行3列表格:

  1. Sub 宏1()
  2.     ActiveDocument.Tables.Add Range:=Selection.Range, NumRows:=2, NumColumns:=3
  3.     Selection.Tables(1).Style = "网格型" '如果不表格样式,看不到边框。
  4. End Sub
复制代码



④Excel导出Word图片:

  1. Sub 复制到Excel后输出1()
  2.     Dim Excel_Shape As Shape
  3.     Dim i As Integer
  4.     Dim Word, Myword As Object
  5.     Set Word = CreateObject("word.application")
  6.     Set Myword = Word.Documents.Open("C:\Users\Brildo\Desktop\test.doc")
  7.     Word.Visible = True
  8.     Application.DisplayAlerts = False '从doc到xls的复制过程可能会报错,故加此句
  9.     For i = 1 To Myword.Shapes.Count
  10.         Myword.Shapes(i).Select
  11.         Word.Selection.Copy
  12.         ActiveSheet.Cells(i, 1).Activate
  13.         ActiveSheet.PasteSpecial Format:="图片(增强型图元文件)", Link:=False, DisplayAsIcon:=False
  14.         Set Excel_Shape = ActiveSheet.Shapes(1) '因为当单个doc中存在图片量过多,均复制到xls中造成数据量过大,
  15.         '这里采用了复制一个进入xls,再另存图片后,立即删除xls中的图片数据,所以遍历时,index永远是1
  16.         Excel_Shape.ScaleHeight 1, True, msoScaleFromMiddle '调整图片大小为原始大小,不缩放
  17.         Excel_Shape.ScaleWidth 1, True, msoScaleFromMiddle
  18.         Excel_Shape.Copy
  19.         With ActiveSheet.ChartObjects.Add(0, 0, Excel_Shape.Width, Excel_Shape.Height).Chart
  20.             .Paste
  21.             .Export ThisWorkbook.Path & "" & i & ".jpg"
  22.             .Parent.Delete '删除第二次复制产生的数据
  23.         End With
  24.         Excel_Shape.Delete '删除第一次复制产生的数据
  25.     Next i
  26. End Sub
复制代码





提取Word表格数据.zip

47.03 KB, 下载次数: 667

提取Word简历

Word导出图片.zip

378.17 KB, 下载次数: 622

Excel操作Word导出图片

Excel批量生成Word合同.zip

56.06 KB, 下载次数: 712

Excel批量生成Word合同

评分

20

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-12-28 14:31 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
3年的沉淀,总结了诸多案例,我把excel与Word交互做成了一系列插件。--Excel魔方
插件地址:https://www.vbashuo.top/exceltool

image.png
生成、提取,只要有规律的需求,基本都可以攻克。

image.png


image.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-3-28 13:13 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2023-3-24 18:03 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-12-30 10:16 | 显示全部楼层
applebuding-201 发表于 2022-12-30 10:06
感谢感谢 请问有没有信息批量制作合同的程序

有的。
插件下载地址:https://www.vbashuo.top/exceltool
image.png

TA的精华主题

TA的得分主题

发表于 2022-12-30 10:06 | 显示全部楼层
感谢感谢 请问有没有信息批量制作合同的程序

TA的精华主题

TA的得分主题

发表于 2022-12-29 18:51 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-12-29 16:07 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
阿囡123 发表于 2019-11-8 00:27
求大师百忙之中帮小女子实现EXCEL与Word数据交换,非常感谢

用我的插件可以完美解决
image.png

TA的精华主题

TA的得分主题

发表于 2022-9-27 14:37 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2021-9-1 14:53 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
真棒,感谢分享
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-19 05:44 , Processed in 0.045605 second(s), 17 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表