ACCESS中通过VBA将EXCEL文档中的多个结构相同的表合并为一个表
时 间:2017-11-05 20:04:07
作 者:Big Young ID:252 城市:襄阳
摘 要:ACCESS中通过VBA将EXCEL文档中的多个结构相同的表合并为一个表。
正 文:
Public Sub MergeWorkSheets(strWrkBookName As String)
Dim objExcelApp As Object
Dim objWorkbook As Object
Dim objWorkSheet As Object
Dim strSQL As String
Set objExcelApp = CreateObject("Excel.application", "")
objExcelApp.Visible = False
Set objWorkbook = objExcelApp.Workbooks.Open(strWrkBookName)
DoCmd.SetWarnings False
For Each objWorkSheet In objWorkbook.Worksheets
'Debug.Print objWorkSheet.Name
If IsNull(DLookup("[Id]", "[MSysObjects]", "[Type]=1 AND [Name]='tempTable'")) Then
strSQL = "Select * INTO tempTable FROM [Excel 12.0 XML;HDR=YES;DATABASE=" & strWrkBookName & "].[" & objWorkSheet.Name & "$];"
Else
strSQL = "Insert INTO tempTable Select * FROM [Excel 12.0 XML;HDR=YES;DATABASE=" & strWrkBookName & "].[" & objWorkSheet.Name & "$];"
End If
DoCmd.RunSQL strSQL
Next
objWorkbook.Close True
objExcelApp.Quit
strSQL = "Select * INTO [Excel 12.0 XML;HDR=YES;DATABASE=" & CurrentProject.Path & "\合并结果输出.xlsx].[合并] FROM tempTable;"
DoCmd.RunSQL strSQL
DoCmd.DeleteObject acTable, "tempTable"
'DoCmd.TransferDatabase acExport, "dBase 5.0", Access.CurrentProject.Path, acTable, "tempTable", "DBFTable", False, False
DoCmd.SetWarnings True
Set objWorkSheet = Nothing
Set objWorkbook = Nothing
Set objExcelApp = Nothing
End Sub
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 【Access选项卡示例】Ac...(09.09)
- 【Access源码示例】按输入...(09.02)
- 【Access日期区间段查询】...(08.29)
- 【Access日期区间段查询】...(08.27)
- Access怎样才能实现日期时...(08.21)
- 【Access定时打开查询】A...(08.19)
- Access生成固定数量的记录...(08.13)
- Access怎样才能实现日期时...(08.12)
- Access利用导航窗体控件对...(08.03)
学习心得
最新文章
- Access表中的字段名、字段标题...(09.19)
- Access快速开发平台--更改“...(09.18)
- 【中秋及国庆优惠】Access培训...(09.15)
- Access如何将日期型的数值转换...(09.14)
- 英文输入法输入数据中存在单引号引起...(09.11)
- 【Access选项卡示例】Acce...(09.09)
- 让Access光标停留在指定的控件...(09.07)
- 关于Access查询条件里使用通配...(09.06)
- Access报表偷懒制作法--Ac...(09.05)
- Access快速开发平台--窗体数...(09.04)