【access小品】逐步扩展--自定义函数编制讲座一
时 间:2011-04-26 00:00:00
作 者:煮江品茶 ID:10802 城市:武汉
摘 要:自定义函数
正 文:
数月前,有版友发贴希望得到函数编制方法的讲座。在我看来,这个事情没法讲,其原因在于函数和模块只是抽象的结果,无一定之规和现成之法。后来风行同志还是尝试着编写了一个讲座的视频,写得很好,对版友们应该有所帮助。通过风行同志的实践,看来函数的编制还是可以讲的,可能着重在于讲编写的策略、处理的思路,抽象的方法。
今日里,版友yinyt 同志问询一个一周内数据的筛选问题,给定的条件是某个确定的日期,要求筛选出本周或者上周或者下周的数据来。就这个问题我编写了自定义函数,编写的过程是我的一个基本习惯,就是由浅入深,逐步推进,逐步扩展。我想对于初学者来说,大都可以采用这一个基本策略进行自定义函数的编写。下面把我的思维过程展示给版友们,希望能对你有所帮助。
首先,我想这个问题的解决关键是得到给定日期所在周的周一日期。于是我编写了以下的函数:
Function Monday(MYDate as Date) as date
'功能:计算给定日期所在周的周一日期
'参数:MyDate--给定日期
'示例:计算下周周一日期 Msgbox Monday(Date)
dim n as long
n=1-Weekday(Mydate,vbMonday)
Monday=DateAdd("d",n,MyDate)
END Function
接下来我考虑版友yinyt 同志需要在上周或者下周进行筛选,于是应该增加一个参数,将函数扩展为能在若干周内找到对应周的周一日期,于是我加入了一个参数m,使函数变化为:
Function Monday(MYDate as Date,m as long) as date
'功能:计算给定日期所在周的周一日期
'参数:MyDate--给定日期,m--0为本周,1为下周,-1为前周
'示例:计算下周周一日期 Msgbox Monday(Date,1)
dim n as long
n=1-Weekday(Mydate,vbMonday)
Monday=DateAdd("d",n,MyDate)
Monday=DateAdd("d",m*7,Monday)
END Function
版友yinyt 同志的真正需求不是仅仅找到周一,而是应该找到某个周的周一和周日日期,这样就可以用Between And 这样的结构来构成筛选的准则了。于是我觉得函数返回的不应该是一个数,而应该是一个数组,这个数组包含了周一和周日的日期。基于此,便将函数最终修改为如下:
Function MYWeekday(MYDate As Date, m As Long) As Variant
'功能:计算给定日期所在周的周一日期与周日日期数组
'参数:MyDate--给定日期,m--0为本周,1为下周,-1为前周
'示例:计算下周周一日期 Msgbox Monday(Date,1)
Dim A(1)
Dim D As Date
Dim n As Long
n = 1 - Weekday(MYDate, vbMonday)
D = DateAdd("d", n, MYDate)
D = DateAdd("d", m * 7, D)
A(0) = D
A(1) = DateAdd("d", 6, D)
MYWeekday = A
End Function
Access软件网官方交流QQ群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 【Access高效办公】按日期...(06.12)
- 合并列数据到一个文本框的示例;...(05.06)
- 通过命令按钮让Access列表...(04.24)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)

学习心得
最新文章
- Access快速开发平台--Acc...(06.16)
- 【Access高效办公】按日期区间...(06.12)
- Access快速开发平台--生成复...(06.07)
- 仓库管理实战课程(25)-导航菜单...(06.06)
- 仓库管理实战课程(24)-库存月结...(06.05)
- 分享一个简单的X氏家谱小示例(06.04)
- 仓库管理实战课程(23)-先入先出(06.02)
- 仓库管理实战课程(22)-代理商库...(05.30)
- 仓库管理实战课程(21)-安全库存...(05.28)
- Access快速开发平台--如何添...(05.26)