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 参数的格式决定。

解决方案 »

  1.   

    Function WeekDay3(nVal As Integer, NYear As Integer) As Variant
        Dim PP As Date
        Dim i As Integer
        Dim Ret(1 To 7) As Date
        
        PP = DateAdd("WW", nVal, CDate(NYear & "-1-1"))
        For i = 1 To 7
            If i < Weekday(PP, vbMonday) Then
                Ret(i) = DateAdd("d", PP, -Weekday(PP, vbMonday) + i)
            Else
                Ret(i) = DateAdd("d", PP, i - Weekday(PP, vbMonday))
            End If
        Next
        WeekDay3 = Ret
    End Function
    调用
    WeekDay 15, 2002
    返回2002年的15周有哪7天
    星期一为第一天
      

  2.   

    Function WeekDay3(nVal As Integer, NYear As Integer) As Variant
        Dim PP As Date
        Dim i As Integer
        Dim Ret(1 To 7) As Date
        
        PP = DateAdd("WW", nVal, CDate(NYear & "-1-1"))
        For i = 1 To 7
            Ret(i) = DateAdd("d", PP, i - Weekday(PP, vbMonday))
        Next
        WeekDay3 = Ret
    End Function上面的麻烦了:)
      

  3.   

    感觉:题目的意思不是很清楚?如果,你是想知道今天是星期几,可用DatePare函数:
        Dim str As String
        str = "星期" & Choose(DatePart("w", Date)
    , "日", "一", "二", "三", "四", "五", "六")
        MsgBox "今天是" & str
    如果有空,请大家到下面的帖子灌灌水……
    http://www.csdn.net/expert/topic/654/654811.xml?temp=.1165583
    主题:  我自认VB水平不错,请大家给我估估价!