设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 6293|回复: 6
打印 上一主题 下一主题

[模块/函数] 【Access小品】一打两就--自定义函数编制讲座五

[复制链接]
跳转到指定楼层
1#
发表于 2011-6-14 21:09:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 todaynew 于 2011-6-15 06:59 编辑

  版友付谦同志问如何导出子窗体中的数据到Excel表中,这个问题有非常多的解法。我想结合这个问题说一下,编写自定义函数时注意其运用的多角度多方面的问题。标题中的“一打两就”是湖北人常用的口头禅,是一石二鸟、一箭双雕的意思。写自定义函数时,要善于拆分功能,使之各个部分能独立的运用。

  我们知道导出Excel表可以用DoCmd.OutputTo、DoCmd.TransferDatabase、DoCmd.TransferSpreadsheet等方法,这类方法使用中有一个条件,就是必须针对数据表或者查询,不能用sql语句字符串。要想用这类方法,就需要建立查询。于是我们可以写一个如下的函数来导出子窗体中的记录:

Public Function 导出E(frm As Form)
'示例:导出E(me.子窗体.form)
Dim Qdef As QueryDef
Dim ssql As String
Dim strwh As String
ssql = frm.RecordSource
ssql = Trim(ssql)
If Right(ssql, 1) = ";" Then
    ssql = Left(ssql, Len(ssql) - 1)
End If
ssql = "select * from (" & ssql & ") where "
strwh = "True"
If frm.Filter <> "" Then
    strwh = strwh & " and " & frm.Filter
End If
ssql = ssql & strwh
Set Qdef = CurrentDb.CreateQueryDef("TempQ")
Qdef.SQL = ssql
DoCmd.OutputTo acOutputQuery, "TempQ", acFormatXLS
DoCmd.DeleteObject acQuery, "TempQ"
Qdef.Close
Set Qdef = Nothing
End Function

  这个函数的处理过程中,实际上进行了三个主要步骤,其一是用子窗体的数据源和筛选获得一个SQL语句字符串,其二是创建一个查询,其三是导出Excel表。这三个步骤中的前两个实际上在其他方面也会有运用,比如可以用第一个步骤得到的sql语句字符串进行ADO计算,再比如用第二个步骤创建查询的方法做其他用途。由此我们就可以考虑到,将上面的函数做功能上的解构,形成相对独立的函数。这样我们可以写三个自定义函数如下:

Public Function GetfrmSql(frm as Form) as String
'得到窗体sql语句字符串
Dim ssql As String
Dim strwh As String
ssql = frm.RecordSource
ssql = Trim(ssql)
If Right(ssql, 1) = ";" Then
    ssql = Left(ssql, Len(ssql) - 1)
End If
ssql = "select * from (" & ssql & ") where "
strwh = "True"
If frm.Filter <> "" Then
    strwh = strwh & " and " & frm.Filter
End If
ssql = ssql & strwh
GetfrmSql=ssql
End Function

Public Function CrtQDef(strname As String, strsql As String)
'创建查询
Dim Qdef As QueryDef
Set Qdef = CurrentDb.CreateQueryDef(strname)
Qdef.SQL = strsql
Qdef.Close
Set Qdef = Nothing
End Function

Public Function AccToExl(frm As Form)
'示例:导出E(me.子窗体.form)
Dim Qdef As QueryDef
Set Qdef = CurrentDb.CreateQueryDef("TempQ")
Qdef.SQL = GetfrmSql(frm)
DoCmd.OutputTo acOutputQuery, "TempQ", acFormatXLS
DoCmd.DeleteObject acQuery, "TempQ"
Qdef.Close
Set Qdef = Nothing
End Function

  通过上面的改造,三个函数均可单独运用于多个方面,也便就起到了一打两就、一石二鸟、一箭双雕的作用了。

本帖被以下淘专辑推荐:

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏3 分享分享 分享淘帖1 订阅订阅
2#
发表于 2011-6-14 22:46:44 | 只看该作者
先下手为强!
3#
发表于 2011-6-15 14:46:42 | 只看该作者
报到,学习!

点击这里给我发消息

4#
发表于 2011-6-15 11:49:25 | 只看该作者
收藏了!
5#
发表于 2011-6-15 13:04:10 | 只看该作者
6#
发表于 2011-8-9 14:56:45 | 只看该作者
学习先
7#
发表于 2011-9-13 07:49:22 | 只看该作者
收藏了!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-12-1 17:36 , Processed in 0.089379 second(s), 33 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表