首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >VBA Excel词典内部词典后期绑定

VBA Excel词典内部词典后期绑定
EN

Stack Overflow用户
提问于 2018-08-02 09:04:53
回答 2查看 1.5K关注 0票数 3

以下代码在调试语句上失败

代码语言:javascript
复制
Sub Tets()
Dim cl_data As Object
Set cl_data = CreateObject("Scripting.Dictionary")
Dim row As Object

Dim irow As Long
For irow = 11 To 12
    Set row = CreateObject("Scripting.Dictionary")
    With row
        row.Add "YN", Cells(irow, 2).Value
        row.Add "Comment", Cells(irow, 3).Value
    End With
    cl_data.Add Cells(irow, 1).Value, row
Next irow
Debug.Print cl_data(CStr(Cells(irow, 1)))("YN")
End Sub

我试着保存A、B和C列中的数据。“外部字典应该以A列的值作为键,内部是另一个字典,其中B列的数据以"YN”键保存,c列的数据由键“注释”保存。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-08-02 09:16:44

这里的问题是在你的循环之后。

代码语言:javascript
复制
For irow = 11 To 12
     '…
Next irow

Debug.Print irow返回13。这不在字典中,因为您只读取行1112

票数 1
EN

Stack Overflow用户

发布于 2018-08-02 09:16:04

尝试将行作为对象数组,并在退出循环后将irow重置为边界内的某个内容。

代码语言:javascript
复制
Sub Tets()

    Dim irow As Long, cl_data As Object, row(11 To 12) As Object

    Set cl_data = CreateObject("Scripting.Dictionary")

    For irow = 11 To 12
        Set row(irow) = CreateObject("Scripting.Dictionary")
        With row(irow)
            .Add "YN", Cells(irow, 2).Value
            .Add "Comment", Cells(irow, 3).Value
        End With
        cl_data.Add Key:=Cells(irow, 1).Value, Item:=row(irow)
    Next irow

    irow = 11
    Debug.Print cl_data(CStr(Cells(irow, 1)))("YN")
    irow = 12
    Debug.Print cl_data(CStr(Cells(irow, 1)))("YN")

End Sub
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51649691

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档