- 新建一个excel到word同级目录
- alt+f11打开vba窗口并新建模块
- 粘贴下方代码(修改一些必要参数)
- 回到excel表格界面,alt+f8选择执行该宏
- 注意要在信任中心开启运行vba宏
vbnet
Sub 批量提取word表格数据到excel()
Dim wdApp As Object, wdDoc As Object
Dim fso As Object, folder As Object, file As Object
Dim excelRow As Long, iRow As Long, iCol As Integer
Dim tableNo As Integer
Dim folderPath As String
tableNo = 1 ' 修改为实际表格序号,默认第一个表格
excelRow = 1 ' Excel起始行
folderPath = ActiveWorkbook.Path & "\" ' word文件所在目录
' 创建文件系统对象
Set fso = CreateObject("Scripting.FileSystemObject")
Set folder = fso.GetFolder(folderPath)
' 初始化Word
On Error Resume Next
Set wdApp = GetObject(, "Word.Application")
If Err.Number <> 0 Then
Set wdApp = CreateObject("Word.Application")
End If
On Error GoTo 0
wdApp.Visible = False ' 隐藏Word窗口
' 遍历文件夹中的每个Word文档
For Each file In folder.Files
If (fso.GetExtensionName(file.Path) = "doc") Or (fso.GetExtensionName(file.Path) = "docx") Then
Set wdDoc = wdApp.Documents.Open(file.Path)
' 检查文档中是否存在表格
If wdDoc.Tables.Count >= tableNo Then
With wdDoc.Tables(tableNo)
' 复制表格数据到Excel
' 1.遍历姓名
For iRow = 5 To 5
For iCol = 2 To 2
' 去除换行符和空格并写入Excel
Cells(excelRow, iCol - 1).Value = WorksheetFunction.Clean(Replace(.Cell(iRow, iCol).Range.Text, vbCr, ""))
Next iCol
excelRow = excelRow + 1
Next iRow
' 2.遍历成绩
For iRow = 3 To 3
For iCol = 5 To 5
' 去除换行符和空格并写入Excel
Cells(excelRow - 1, iCol - 3).Value = WorksheetFunction.Clean(Replace(.Cell(iRow, iCol).Range.Text, vbCr, ""))
Next iCol
excelRow = excelRow
Next iRow
' 3.遍历其他数据信息
' ' ' ' ' ' '
End With
End If
wdDoc.Close SaveChanges:=False
End If
Next file
' 清理缓存数据
wdApp.Quit
Set wdDoc = Nothing
Set wdApp = Nothing
Set fso = Nothing
MsgBox "提取完毕!找到文件数量:" & folder.Files.Count-2
End Sub