gpt4 book ai didi

excel - 函数 optional 参数日期类型失败

转载 作者:行者123 更新时间:2023-12-04 21:17:04 25 4
gpt4 key购买 nike

我有一个函数可以找到下一个星期一的日期。当没有传递 optional 日期参数时,它会默认为零。我想我已经包含了解释问题的评论

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

最佳答案

VBA 变量通常具有默认值,并且任何 optional 参数都会自动设置为其默认值,因此这种行为是意料之中的。既然您已经知道如果未通过 optional 参数将默认为 0 (1/1/1900),为什么不只测试该值而不是测试是否传入了日期?

另一方面,如果您认为有人可能需要传入 1/1/1900,那么您应该将 optional 参数设置为 Variant类型。变量在 optional 传入时不会被初始化,因此它不会有默认值(与日期不同)。

关于excel - 函数 optional 参数日期类型失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18497942/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com