2

我正在使用从 Microsoft 复制的函数,该函数采用列号并重新分配列字母。我需要这样做来创建一个公式。我已经研究了一整天,无法查明错误的原因(我也尝试将其作为子进程来完成)。该功能在其自己的模块中。我测试了它,它工作正常:

Function ConvertToLetter(ByRef iCol As Integer) As String
  Dim iAlpha As Integer
  Dim iRemainder As Integer
  iAlpha = Int(iCol / 27)
  iRemainder = iCol - (iAlpha * 26)
  If iAlpha > 0 Then
     ConvertToLetter = Chr(iAlpha + 64)
  End If
  If iRemainder > 0 Then
     ConvertToLetter = ConvertToLetter & Chr(iRemainder + 64)
  End If
End Function

给我一个错误的代码是:

For groups = 1 To i ' level 1 grouping
    For iCol = 24 To 136
       rCol = ConvertToLetter(iCol)
       Cells(Start(groups) - 1, rCol).Formula = "=COUNTA(" & rCol & Start(groups) & ":" & rCol & Finish(groups) & ")"
    Next
Next

我尝试将函数代入公式本身:

  Cells(Start(groups) - 1, ConvertToLetter(iCol)).Formula = "=COUNTA(" & ConvertToLetter(iCol) & Start(groups) & ":" & ConvertToLetter(iCol) & Finish(groups) & ")"

调试器通过了第一个函数调用,但没有通过第二个和第三个函数调用。我收到的错误是“期望变量或过程,而不是模块”的类型。在第二种情况下,我得到了其他错误,我的脑袋很模糊,我想不起来了。

任何帮助是极大的赞赏。我已经没有想法了。非常感谢!

4

3 回答 3

2

您几乎不需要将列转换为字母。首先考虑使用FormulaR1C1

For groups = 1 To i ' level 1 grouping
    For iCol = 24 To 136
        lLast = Finish(groups) - Start(groups) + 1
        Sheet1.Cells(Start(groups) - 1, iCol).FormulaR1C1 = _
            "=COUNTA(R[1]C:R[" & lLast & "]C)"
    Next iCol
Next groups

如果不喜欢R1C1,可以直接用Address

For groups = 1 To i ' level 1 grouping
    For iCol = 24 To 136
        Set rStart = Sheet1.Cells(Start(groups), iCol)
        Set rEnd = Sheet1.Cells(Finish(groups), iCol)

        rStart.Offset(-1, 0).Formula = _
            "=COUNTA(" & rStart.Address & ":" & rEnd.Address & ")"

    Next iCol
Next groups
于 2013-04-04T20:03:58.240 回答
1

以下函数将列号转换为字母:它利用该.Address方法大大简化了生活。

Function convertToLetter(colnum)
mycell = [A1].Offset(0, colnum - 1).Address
convertToLetter = Mid(mycell, 2, Len(mycell) - 3)
End Function

但是现在我查看了您的代码 - 当您使用该Cells功能时,您应该使用数字而不是字母来调用它。所以你有另一个问题!

尝试以下操作:

For groups = 1 To i ' level 1 grouping
    For iCol = 24 To 136
       rCol = ConvertToLetter(iCol)
       Cells(Start(groups) - 1, iCol).Formula = "=COUNTA(" & rCol & Start(groups) & ":" & rCol & Finish(groups) & ")"
    Next
Next

注意我在语句的一部分中iCol没有使用。这可能不是唯一的错误......rColCells(Start(groups)-1, iCol) =

于 2013-04-04T19:21:54.047 回答
1

您使用的功能有问题。检查这个例子

Sub Sample()
    Dim iCol As Integer
    For iCol = 131 To 134
        Debug.Print iCol; ConvertToLetter(iCol)
    Next iCol
End Sub


Function ConvertToLetter(ByRef iCol As Integer) As String
    Dim iAlpha As Integer
    Dim iRemainder As Integer
    iAlpha = Int(iCol / 27)
    iRemainder = iCol - (iAlpha * 26)
    If iAlpha > 0 Then
       ConvertToLetter = Chr(iAlpha + 64)
    End If
    If iRemainder > 0 Then
       ConvertToLetter = ConvertToLetter & Chr(iRemainder + 64)
    End If
End Function

输出

131 D[
132 D\
133 D]
134 D^

使用我从我提到的链接中获取的这段代码。

rcol = Split(Cells(, iCol).Address, "$")(1)

代替

rCol = ConvertToLetter(iCol)
于 2013-04-04T19:22:19.623 回答