日期相加,但不包括非工作日时间的问题.

ynhgk 2011-03-05 04:30:33
请问vb代码如何实现日期相加,但不包括非工作日时间的问题.
如:今日是2011-3-4,加3天为2011-3-9
今日是2011-3-5,加3天为2011-3-9
...全文
158 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
贝隆 2011-03-05
  • 打赏
  • 举报
回复
请详细参阅:
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设置决定
王二.麻子 2011-03-05
  • 打赏
  • 举报
回复
如果你要用日期时间,请使用date数据类型。

Dim a As Date
a = "2011-3-4 12:12:12"
Debug.Print a
a = a + 3'加了3天
Debug.Print a'打印2011-3-7 12:12:12
Debug.Print Int(a) '打印日期部分2011-3-7
Debug.Print a + "0:0:1" '打印时间+1秒的一个date 2011-3-7 12:12:13
Dim b As Date
b = "2011-3-8"
Debug.Print CDate(b - a) '打印"2011-3-8"和“2011-3-7 12:12:13"的时间差11:47:48,竟然多了1秒,呵呵,如果debug.print "2011-3-8"-a会提示错误

另外,date数据类型,整数部分代表日期部分,小数部分代表时分秒部分,也可以理解为date是double类型的一个变种。
无·法 2011-03-05
  • 打赏
  • 举报
回复
以下代码仅排除周六和周日:

Option Explicit

Private Sub Form_Load()
MsgBox addDate("2011-3-4", 3)
MsgBox addDate("2011-3-5", 3)
MsgBox addDate("2011-3-7", 6)
End Sub

Private Function addDate(d1 As Date, ByVal intAdd As Integer) As Date
Dim intWeek%
Do While intAdd > 0
d1 = DateAdd("d", 1, d1)
intWeek = Weekday(d1, vbMonday)
If intWeek <> 6 And intWeek <> 7 Then intAdd = intAdd - 1
Loop
addDate = d1
End Function
dbcontrols 2011-03-05
  • 打赏
  • 举报
回复
是啊,产假也算“非工作日”吧?婚假事假病假怎么处理?
  • 打赏
  • 举报
回复
工作日……要不要考虑国庆啥的?
如果单纯星期六星期天,可在加几天的几上做文章:满7减2,剩下的需要获取是否为星期六和星期天,是则忽略

7,789

社区成员

发帖
与我相关
我的任务
社区描述
VB 基础类
社区管理员
  • VB基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧