gpt4 book ai didi

class - VBA 使用一个类作为另一个类的属性

转载 作者:行者123 更新时间:2023-12-02 22:10:11 24 4
gpt4 key购买 nike

我在使用作为另一个类的属性创建的类时遇到问题。我有两个类,一个称为“顶点”,另一个称为“边缘”。 Edge 的两个属性(Parent 和 Child)是 Vertex 对象。这是我尝试使用它们的方法。

Option Explicit

Public Sub OrgChart()

Dim Vertices As Collection
Dim Edges As Collection
Dim vParent As Vertex
Dim vChild As Vertex
Dim eEdge As Edge
Dim rEdgeRow As Range

Set rEdgeRow = ActiveSheet.Range("A1:C1")

Do While Len(rEdgeRow(1, 1).Value) > 0

Set vChild = New Vertex
Set vParent = New Vertex
Set eEdge = New Edge

vChild.Name = rEdgeRow(1, 1).Value
vChild.Dummy = False

vParent.Name = rEdgeRow(2, 1).Value
vParent.Dummy = False

eEdge.Parent = vParent
eEdge.Child = vChild
eEdge.Percent = rEdgeRow(3, 1).Value

Set rEdgeRow = rEdgeRow.Offset(1, 0)

Loop

End Sub

当我运行这个时,我收到错误,

“运行时错误'91':未设置对象变量或With block 变量”

调试器表明它在该行处中断

eEdge.Parent = vParent

我认为问题与 eEdge.Parent 未初始化有关,但我尝试使用

Set eEdge.Parent = New Vertex

我也遇到了同样的问题。

如果有帮助,我也可以发布类代码,尽管它们相当简单,仅包含 Property Get 和 Property Let 函数。

如果我在发布此内容时做错了什么,我深表歉意;这是我第一次在 SO 上发布任何内容。

谢谢,埃里克

最佳答案

我可能没有理解这一点,但你尝试过吗:

Set eEdge.Parent = vParent
Set eEdge.Child = vChild

如果它们是对象,则需要使用“Set”

...另外,如果这不能解决问题,您可以发布 Vertex 类的代码吗 - 您可能需要在其构造函数中以不同的方式调暗 Parent 和 Child 对象...

关于class - VBA 使用一个类作为另一个类的属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12940053/

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