VBA实现:将Word中的数据批量提取到Excel
创作时间:
作者:
@小白创作中心
VBA实现:将Word中的数据批量提取到Excel
引用
CSDN
1.
https://blog.csdn.net/nianfen/article/details/141275460
提取Word文档中特定信息到Excel,Word文档结构如下(需提取内容已经用黄色标识):
思路
一个文档中,有多个这样的缴费清单,我们要提取的是一些固定关键字之后的数据。
所以,我们循环文档的所有段落,如果包含【物业管理清册】关键字,则获取他的下两行数据,并且提取关键字。
具体代码
Sub 循环打开工作簿()
On Error GoTo 1
k = 1
Rows("2:65536").Clear '清除上次数据
Application.DisplayAlerts = False
Application.ScreenUpdating = False
Application.AskToUpdateLinks = False
pth = Application.GetOpenFilename("文件(*.doc*),*.doc*", , "请选择文件", , False) '打开doc后缀的文档
If pth = "False" Then Exit Sub '如果用户选择了取消,直接退出
Set doc = CreateObject("word.application") '创建Word对象
doc.Visible = True '显示word主程序
Set wd = doc.Documents.Open(pth) '打开word文档,赋值给对象变量wd
For Each tbl In wd.tables '删除文档中所有的表格,因为表格过多,影响循环段落的效率。
tbl.Delete
Next
For i = 1 To wd.Paragraphs.Count - 2 '循环到倒数第三段
a = wd.Paragraphs(i).Range.Text '获取这几段的内容,分别赋值给a、b、c变量
b = wd.Paragraphs(i + 1).Range.Text
c = wd.Paragraphs(i + 2).Range.Text
If InStr(a, "物业管理费缴费清册") Then '开始取数据
k = k + 1
Cells(k, 1) = k - 1 '序号
Cells(k, 2) = l(Split(Split(b, ":")(1), "面积")(0)) '楼号楼室
Cells(k, 3) = l(Split(Split(b, "面积")(1), "㎡")(0)) '面积
Cells(k, 4) = l(Split(Split(c, "姓名")(1), "电话")(0)) '姓名
Cells(k, 5) = l(Split(Split(c, "电话")(1), "月缴费")(0)) '电话
Cells(k, 6) = l(Split(Split(c, "月缴费")(1), "元")(0)) '月缴费
Cells(k, 7) = l(Split(Split(c, "年缴费")(1), "元")(0)) '年缴费
End If
Next
1: wd.Close False '关闭原始文档,并且不保存
doc.Quit '关闭Word主程序
Application.DisplayAlerts = True
Application.ScreenUpdating = True
Application.AskToUpdateLinks = True
If Err.Number <> 0 Then
MsgBox Err.Description & vbCrLf & "提取出现错误,联系作者解决!"
End If
MsgBox "提取完成!"
End Sub
Function l(s)
l = Replace(s, ":", "") '去除冒号自定义函数
End Function
知识点
- Excel创建Word程序对象
这里使用后期绑定的方式创建Word主程序,并且新建一个word文档。向Word文档中写入内容123,最后另存为本工作簿路径下的一个文档。
'后期绑定
Sub 操作word1() '打开Word写入文字
Set doc = CreateObject("word.application") '创建Word对象
Set wd = doc.Documents.Add
doc.Visible = True
strr = 123 '需要导入的字符串
.TypeText strr
.TypeParagraph
wd.SaveAs ThisWorkbook.Path & "\例子.docx"
doc.Quit '关闭程序
End Sub
- Split函数
关于Split函数,可以看之前的两篇文章,都有详细的讲解。 - Split函数应用|分离商品和数量
- 字符串函数Split的妙用
- GetOpenFilename函数
想弹出对话框,打开某些特定后缀的文件,就用GetOpenFilename。具体用法可参见之前的文章。获取文件全路径(一)GetOpenFilename 方法
常用的代码是以下的模板:
'允许选择多个文件
Sub 循环打开工作簿()
Application.DisplayAlerts = False
Application.ScreenUpdating = False
Application.AskToUpdateLinks = False
pth = Application.GetOpenFilename("文件(*.xls*),*.xls*", , "请选择文件", , True)
If IsArray(pth) = False Then Exit Sub
For i = 1 To UBound(pth)
Set wb = Workbooks.Open(pth(i))
'########汇总数据的核心操作##########
wb.Close False
Next
Application.DisplayAlerts = True
Application.ScreenUpdating = True
Application.AskToUpdateLinks = True
End Sub
'只允许选择一个文件
Sub 循环打开工作簿()
Application.DisplayAlerts = False
Application.ScreenUpdating = False
Application.AskToUpdateLinks = False
pth = Application.GetOpenFilename("文件(*.xls*),*.xls*", , "请选择文件", , False)
Set wb = Workbooks.Open(pth)
'########汇总数据的核心操作##########
wb.Close False
Application.DisplayAlerts = True
Application.ScreenUpdating = True
Application.AskToUpdateLinks = True
End Sub
热门推荐
医生忠告:结石患者,冬天最好少吃这2种豆制品,再想吃也要忍住
小米SU7智驾预警后4秒内碰撞?专家:目前看AEB或没介入并刹停
郁金香浇水的正确方法(掌握浇水技巧,让郁金香舒适成长)
郁金香栽培
口腔健康,身心皆安——老年人的口腔保健之道
股票持有成本包括哪些费用:了解股票持有成本中包含的费用有哪些?
古时候的三字怎么写?——探寻汉字演变的历史足迹
512GB固态硬盘与256GB速度对比分析,究竟哪款更快
网络安全如何分区硬盘
人民币兑美金币汇率中银走势趋势预测
罗伯特·卡洛斯和马塞洛,两个伟大的巴西左后卫,谁更优秀?
动静结合,形神并养:97岁国医大师周信有的“四大国粹”养生法
工伤大脚趾断了能评到几级
工业路由器的技术创新与应用
一周跳绳训练与热身教程详解:从新手到进阶轻松掌握
呼吸阀工作原理揭秘:保障储罐安全与节能
揭秘小蝌蚪为何钟情荷叶:一个自然界的生存智慧
荒诞喜剧的隐喻表达与社会讽刺,独特的艺术观察之道
最简单的小船的折法 带篷折纸船的方法图解
复盘的意思是什么?
细胞计数专题 | 如何进行细胞计数:细胞计数方法概览
OTC红色和绿色的区别有哪些
张家口湿地何以美出圈
线上保险跟线下保险理赔有区别吗
如何在 iPhone 上截屏:所有方法
基遇周谈 | 权益市场周动态
股价大涨46% 创年内新高!A股最热门板块 机构扎堆调研
Win11设置网络为固定IP后无法上网的解决方案
世界十大最长寿犬种排行:揭秘长寿基因
老面馒头(碱面详细做法)