Access交流中心

北京 | 上海 | 天津 | 重庆 | 广州 | 深圳 | 珠海 | 汕头 | 佛山 | 中山 | 东莞 | 南京 | 苏州 | 无锡 | 常州 | 南通 | 扬州 | 徐州 | 杭州 | 温州 | 宁波 | 台州 | 福州 | 厦门 | 泉州 | 龙岩 | 合肥 | 芜湖 | 成都 | 遂宁 | 长沙 | 株洲 | 湘潭 | 武汉 | 南昌 | 济南 | 青岛 | 烟台 | 潍坊 | 淄博 | 济宁 | 太原 | 郑州 | 石家庄 | 保定 | 唐山 | 西安 | 大连 | 沈阳 | 长春 | 昆明 | 兰州 | 哈尔滨 | 佳木斯 | 南宁 | 桂林 | 海口 | 贵阳 | 西宁 | 乌鲁木齐 | 包头 |

如何自动计算一年后的日期

九面  发表于:2010-07-05 02:21:52  
复制

请教各位老师

我在窗体中设置了文本框1和文本框2,当我在文本框1中输入当前日期或自己选择的日期后,文本框2会自动显示出一年的日期,如文本框1中输入:2010-7-5,文本框2中显示为:2011-7-4,我用了一个命令:ME.文本框2 = ME.文本框1+364,可是在闰年、闰月的情况下,这样就出现错误了,如:文本框1中输入:2011-7-5,文本框2中显示为:2012-7-3,而不是我要的:2012-7-4。这个问题该如何用代码处理

 

Top
wj.s 发表于:2010-07-05 03:00:06

Me.文本框2 = DateAdd("yyyy", 1, Me.文本框1)

"文本框2会自动显示出一年的日期,如文本框1中输入:2010-7-5,文本框2中显示为:2011-7-4"

正确的一年之后的日期应该是2011-7-5

DateAdd()函数帮助(VBA里的帮助):

DateAdd 函数

       

返回包含一个日期的 Variant (Date),这一日期还加上了一段时间间隔。

语法

DateAdd(interval, number, date)

DateAdd 函数语法中有下列命名参数

部分 描述
interval 必要。字符串表达式,是所要加上去的时间间隔。
number 必要。数值表达式,是要加上的时间间隔的数目。其数值可以为正数(得到未来的日期),也可以为负数(得到过去的日期)。
date 必要。Variant (Date) 或表示日期的文字,这一日期还加上了时间间隔。

设置

interval 参数具有以下设定值:

设置 描述
yyyy
q
m
y 一年的日数
d
w 一周的日数
ww
h
n 分钟
s

说明

可以使用 DateAdd 函数对日期加上或减去指定的时间间隔。例如,可以用 DateAdd 来计算距今天为三十天的日期;或者计算距现在为 45 分钟的时间。

为了对 date 加上“日”,可以使用“一年的日数” (“y”),“日” (”d”) 或“一周的日数” (”w”)。

DateAdd 函数将不返回有效日期。在以下实例中将 1 月31 日加上一个月:

DateAdd(m, 1, 31-Jan-95)

上例中,DateAdd 返回 1995 年 2 月 28 日,而不是 1995 年 2 月 31 日。如果 date 是 1996 年 1 月 31 日,则由于 1996 年是闰年,返回值是 1996 年 2 月 29 日。

如果计算的日期超前 100 年(减去的年度超过 date 中的年份),就会导致错误发生。

如果 number 不是一个 Long 值,则在计算时取最接近的整数值来计算。

注意   DateAdd 返回值的格式由 Control Panel设置决定,而不是由传递到date 参数的格式决定。



九面 发表于:2010-07-05 04:51:48

谢谢W教授,我得到了满意的结果!

我的要求中:"文本框2会自动显示出一年的日期,如文本框1中输入:2010-7-5,文本框2中显示为:2011-7-4",是因为工作关系,我需要文本框1的0时起至文本框2的24时止,我把你给我的答复修改了一下:Me.文本框2 = DateAdd("yyyy", 1, Me.文本框1)-1,这样就满足了我的要求,我没有进一步测试闰年、闰月的情况下这种修改是否正确,但还是谢谢你!



九面 发表于:2010-07-05 04:59:50
如果我在文本框1下输入2012-2-29,文本框2应该是2013-2-28,但显示的是:2013-2-27,看来我的修改是不对的,闰月的问题看来还是没解决

wj.s 发表于:2010-07-05 12:53:48

加个日的判断,如果获得的日期>=文本框1的值才-1,否则不-1,应该可以解决,还有按你这情况月初的1号-1的话会回到上月月末,也要考虑



总记录:4篇  页次:1/1 9 1 :