我有一个函数可以找到下一个星期一的日期。当没有可选的日期参数传递时,它将变为默认值零。我想我已经包含注释来说明问题Excel VBA - 函数可选参数DATE类型失败
Function NextMondayFromADateOrToday(Optional StartDate As Date) As Date
' objective: if date param not supplied should set StartDate to today
' ??? Problem: with no arg provided StartDate is zero = date value of 1/1/1900
' ??? how to add default to optional paramater of date type?
' ??? or, how to check if an arg was provided if the parameter is date type?
If Not (IsDate(StartDate)) Then StartDate = Date
Select Case Weekday(StartDate)
Case 1: NextMondayFromADateOrToday = StartDate + 1
Case 2: NextMondayFromADateOrToday = StartDate + 0
Case 3: NextMondayFromADateOrToday = StartDate + 6
Case 4: NextMondayFromADateOrToday = StartDate + 5
Case 5: NextMondayFromADateOrToday = StartDate + 4
Case 6: NextMondayFromADateOrToday = StartDate + 3
Case 7: NextMondayFromADateOrToday = StartDate + 2
End Select
End Function
非常感谢。我希望有更优雅的东西,尤其是一种设定日期默认值的方法。但是你说的话很有道理,我已经尝试过并且工作得很好。非常感谢。 –
很高兴工作。如果你想在没有日期通过时设置默认日期,你需要使用Variant,然后像ooo写的那样测试它'如果IsMissing(StartDate)Then ...'。无论您采用哪种答案,都不要忘记将其标记为已接受。 – techturtle