Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> ADO/DAO/ADO.NET  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701940
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

如何将整个 MDB 中所有的表全部导出到一个 XLS 中去?

作者:cg1  摘自:access911.net  :cg1  更新日期:2006-12-12  浏览人次:

 

问题:

如何将整个 MDB 中所有的表全部导出到一个 XLS 中去?
要求一个表存为一个 SHEET ,SHEET 名就是表名

 

回答:


新建一个模块,然后将下列代码复制进去,按 F5 运行即可

'===========================================================
' 过程及函数名:  ExportTableToOneXls
' 版本号      :  1.0
' 说明        :  本函数作用:将当前 MDB 中的所有用户表导出到
'                 某一个 Excel 的 XLS 中去
' 引用        :  ADO 2.1 及以上版本
' 输入参数    :  XlsPath 文本,目标 XLS 的绝对路径
' 输出值      :  --
' 返回值      :  --
' 调用演示    :  ExportTableToOneXls "c:\tempExEg.xls"
'                 (或请直接看 test 过程。)
' 最后修改日期:  2006-12-12 16:22:00
' 示例地址    :  http://access911.net/?kbid;72FABE1E15DCECF3
' 作者        :  cg1
' 网站        :  http://access911.net
' 电子邮件    :  access911@gmail.com
' 版权        :  作者保留一切权力,
'                 请在公布本代码时将本段说明一起公布,谢谢!
'===========================================================

'Alt + F11 键切换到 VBA 编辑器界面
'引用 ADO 2.1 及以上版本
'菜单 -> 工具 -> 引用 -> Microsoft ActiveX Data Objects 2.1 Library 前面打勾 -> 确定

Public Function ExportTableToOneXls(ByVal XlsPath As String)
    
    '这里用 ADO 来获取所有的表名,当然,你完全可以用查询系统表的方法来实现
    '   《表》怎样使用一个查询获得数据库对象的名称(查询/窗体/表/报表/模块/宏)?查询系统表的方法
    '   http://access911.net/index.asp?u1=a&u2=71FAB71E12DC

    
    Dim rstSchema As ADODB.Recordset
    Dim cnn2 As ADODB.Connection
    Set cnn2 = CurrentProject.Connection
    Set rstSchema = cnn2.OpenSchema(adSchemaTables)
    Dim i As Long
    Do Until rstSchema.EOF
        If rstSchema("TABLE_TYPE") = "TABLE" Then
            '对应 TABLE_TYPE 可以取值 "TABLE" "SYSTEM TABLE" "ACCESS TABLE"
            '在这里我们列出所有用户表的信息,系统表不列出

            For i = 0 To rstSchema.Fields.Count - 1
                Debug.Print rstSchema(i).Name & "-> " & rstSchema.Fields(i).Value
                If rstSchema(i).Name = "TABLE_NAME" Then
                    '用 TransferSpreadsheet 实现导出,当然,你完全可以用 in 子句来实现
                    '    《查询》如何查询其他数据库内的表(IN子句实例)?
                    '    http://access911.net/index.asp?u1=a&u2=71FAB21E17DC

                    DoCmd.TransferSpreadsheet acExport, acSpreadsheetTypeExcel9, rstSchema.Fields(i).Value, XlsPath, True
                End If
            Next
        End If
        rstSchema.MoveNext
    Loop
    rstSchema.Close
    cnn2.Close
End Function


Public Function test()
'请将光标停留在这里并按 F5 键运行
    ExportTableToOneXls "c:\tempExEg.xls"
End Function


完整实例下载:
http://access911.net/down/eg/eg_ExportAllTableToAXls.rar
 (14KB)


 

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
     如何在导出表到EXCEL时让用户随意选择字段?
     一个将数据导出到EXCEL的存储过程
     新手来看:我是否可以将Excel数据导入?
     新手来看:如何将数据表导出备份到excel表格
     如何制作复杂报表——利用Excel输出复杂报表
     如何将ACCESS MDB 中的表导出成文本格式
     如何实现ACCESS数据及对象的导入导出?
     如何用程序实现链接有“打开密码”的 XLS 表格?
     如何将表导出为ASP文件?
     SQL SERVER 与ACCESS、EXCEL的数据转换
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利