0

我有一个包含多张工作表的工作簿。除摘要表外,所有其他表都有一个动态范围的连续单元格(在一列内),这些单元格存储了一些日期格式的值。我需要动态选择该范围并选择最大日期值。函数应该返回该值。

这是我正在尝试的:

Function GetMSDate(Counter As Integer, DesignCtrs() As String, NumOfVendors() As Long, 
          MSDesc() As String, PlanOrActual As String) As Date
    GetMSDate = Application.Max(ThisWorkbook.Worksheets(Counter + 1).Range("A:A")
            .Find(PlanOrActual, SearchOrder:=xlByColumns, searchDirection:=xlNext)
            .EntireRow
            .Find(MSDesc(1), SearchOrder:=xlByColumns, searchDirection:=xlNext)
            .Offset(1, 0).Address & ":" & _
            ThisWorkbook.Worksheets(Counter + 1).Range("A:A")
            .Find(PlanOrActual, SearchOrder:=xlByColumns, searchDirection:=xlNext)
            .EntireRow
            .Find(MSDesc(1), SearchOrder:=xlByColumns, searchDirection:=xlNext)
            .Offset(NumOfVendors(Counter) + 1, 0).Address)
    MsgBox GetMSDate
End Function

我的意图是为Application.Max()参数定义动态构造的 Range。在这样做时,找到范围锚,我选择了正确的工作表(Counter+1允许正确);然后在第一列中找到一个特定的“预定义”字符串;选择找到的单元格的整行并在该范围内找到另一个预定义的字符串;然后定义范围从该锚单元下方的单元到由以下定义的偏移量:NumOfVendors(Counter)+1

在运行上述内容时,它给了我:

在“GetMSDate =”语句中键入不匹配错误。

4

1 回答 1

1

要进行调试,请将您的值分配给一个变体变量,然后在分配后输出该变量的 typename()。它应该告诉你为什么它不接受日期。

Function GetMSDate(Counter As Integer, DesignCtrs() As String, NumOfVendors() As Long, MSDesc() As String, PlanOrActual As String) As Date
    Dim v as Variant

    v = Application.Max(ThisWorkbook.Worksheets(Counter +
        1).Range("A:A").Find(PlanOrActual, SearchOrder:=xlByColumns,
        searchDirection:=xlNext).EntireRow.Find(MSDesc(1), SearchOrder:=xlByColumns,
        searchDirection:=xlNext).Offset(1, 0).Address & ":" & _
    ThisWorkbook.Worksheets(Counter + 1).Range("A:A").Find(PlanOrActual,
        SearchOrder:=xlByColumns, searchDirection:=xlNext).EntireRow.Find(MSDesc(1),
        SearchOrder:=xlByColumns, searchDirection:=xlNext).Offset(NumOfVendors(Counter)
        + 1, 0).Address)
    debug.print v
    debug.print TypeName(v)
    stop
    MsgBox GetMSDate
End Function
于 2013-03-08T18:23:53.257 回答