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
热门推荐
建筑公司提升工程施工综合效率的策略与实践
【冬季护眼指南】想要这个冬季少涨度数,应该怎么保护眼睛?
饮料伤肾吗?医生解析不同饮料对肾脏的影响
内蒙古大学档案查询指南:线上查询与现场咨询全攻略
如何消除恐惧心理以提升驾驶信心?有哪些心理调适方法和实践技巧?
哲学新书联合书单|拉康论爱
吃姜恶心胃疼想吐怎么缓解
喝完咖啡心慌如何缓解
没有充气泵的情况下怎样为轮胎充气?这种充气方法的安全性如何?
视力下降、视物模糊,除了用眼疲劳,也可能是这几种疾病导致
跳绳、爬楼梯、跑步哪个更伤膝盖?一文读懂运动与膝盖健康的关系
升学礼物指南:10个维度帮你挑选完美礼物
电池类型和这些电池的定义
证件照自己在家怎么拍?
日本米价高涨,政府首次投放储备米能否“降温”?
家用车多大马才算够用?对比一下这几款车的推重比就明白了!
如何选择和参与A-Level课外活动提升个人竞争力
【科普】安宫牛黄丸是救命药还是保健品?如何正确使用?
DNF智力属性详解:高智力角色职业选择与培养指南
糖友血糖之惑:家与医院为何不同?
团体意外险怎么赔偿?赔偿标准及流程详解
自耦变压器
为什么水生动物都有类似的腥味?
SUV与普通轿车的主要区别是什么?
科普果酸焕肤治疗效果、副作用、适合人群知识点
深圳信息职业技术学院拟升本!附2024年录取分数线
教师体罚学生是否违法及其法律后果探析
误杀案件应判什么罪:法律适用与实务认定
一、泛智教育与统一学制
痛风患者可以喝茶吗?一文详解茶与痛风的关系