excel - 私有(private)函数跳过 For 循环

标签 excel vba dictionary

我现在正在尝试学习字典在 VBA 中是如何工作的,所以我创建了一个简单的类模块、一个函数,然后是两个子模块,但出于我之外的原因 For循环在函数内被完全跳过。以下是上述所有项目的代码。我确实在工具 > 引用中检查了 Microsoft 脚本运行时。我不太熟悉如何使用后期和早期绑定(bind),所以我想知道这是否是问题之一。

目前Set rg = LoanData.Range("AH2")在表格中,我已经尝试将该范围内的数据作为表格和范围,但是 For如果数据在表中,则跳过函数中的循环。

Data Set

名为 clsCounty 的类模块

Public CountyID As Long
Public County As String

名为 ReadCounty 的函数
Private Function ReadCounty() As Dictionary
    Dim dict As New Dictionary

    Dim rg As Range
    Set rg = LoanData.Range("AH2")

    Dim oCounty As clsCounty, i As Long


    For i = 2 To rg.Rows.Count

        Set oCounty = New clsCounty

        oCounty.CountyID = rg.Cells(i, 1).Value
        oCounty.County = rg.Cells(i, 2).Value

        dict.Add oCounty.CountyID, oCounty
    Next i

    Set ReadCounty = dict


End Function

要写入即时窗口的两个潜艇
Private Sub WriteToImmediate(dict As Dictionary)
    Dim key As Variant, oCounty As clsCounty

    For Each key In dict.Keys
        Set oCounty = dict(key)
        With oCounty
            Debug.Print .CountyID, .County
        End With
    Next key

End Sub

Sub Main()
    Dim dict As Dictionary

    Set dict = ReadCounty

    WriteToImmediate dict

End Sub

最佳答案

您已将您的范围声明为 Set rg = LoanData.Range("AH2")然后使用 For i = 2 To rg.Rows.Count在你的循环中。 rg.Rows.Count将是 1因为您的范围内只有 1 个单元格。这是您的 For 的起始值之前。循环( 2 )所以它不会做任何事情。

For i = 2 to 1
声明您的rg变量与全范围。我会猜测类似的东西

With LoanData
    Set rg = .Range(.Cells(1,"AH"), .Cells(.Cells(.Rows.Count, "AH").End(xlUp).Row, "AH"))
End With

关于excel - 私有(private)函数跳过 For 循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56526570/

相关文章:

vba - 仅在 Excel 中的几列中打开/关闭自动计算

excel - 比较 A 列和 B 列并创建包含仅存在于 A 列中的值的新列

c# - C# HashSet 是否通过 Equals 然后通过 GetHashCode 检查重复项?

java - 迭代 HashMap,两种方式 : iterating with entry set & iterating with enumeration

algorithm - 这个 SuperFashHash 实现是否计算字符串的正确 31 位散列?

vba - Excel VBA以编程方式将代码添加到工作表模块

java - 如何使使用 IKVM com 创建的 .dll 可见?

vba - EXCEL VBA : comparing day & month only from all the date

excel - 在 Excel/Calc 中将文本反转为列

python - 在不丢失数据的情况下更新字典