[英]Dynamically Populate VBA Array
在下面的示例語法中,如何將每個元素添加到新數組而不是打印? 我不確定該怎么做,因為我不知道數組的大小,因為它可能是 0(不需要初始化數組)或者它可能是它正在迭代的數組的Ubound
。
Option Compare Database
Option Explicit
Function TestIt()
Dim animalarray As Variant, xyz As Variant
animalarray = Array("Cat", "Cow", "Camel", "Dire Wolf", "Dog", "Coyote", "Rabbit", "Road runner", "Cougar")
For Each xyz In animalarray
If Left(CStr(xyz), 1) = "C" Then
Debug.Print CStr(xyz)
End If
Next
End Function
您可以使用Redim Preserve
:
Sub TestIt()
Dim animalArray(): animalArray = Array("Cat", "Cow", "Camel", "Dire Wolf", "Dog", "Coyote", "Rabbit", "Road runner", "Cougar")
Dim anotherArray(): anotherArray = Array("Lion", "Tiger", "Leopard")
Dim xyz As Variant
For Each xyz In animalArray
If Left(CStr(xyz), 1) = "C" Then
ReDim Preserve anotherArray(UBound(anotherArray) + 1)
anotherArray(UBound(anotherArray)) = xyz
End If
Next
For Each xyz In anotherArray
Debug.Print xyz
Next
End Sub
甚至更簡單:
Function TestIt()
Dim animalarray As Variant
Dim newarray As Variant
Dim xyz As Variant
animalarray = Array("Cat", "Cow", "Camel", "Dire Wolf", "Dog", "Coyote", "Rabbit", "Road runner", "Cougar")
newarray = animalarray
For Each xyz In newarray
If Left(CStr(xyz), 1) = "C" Then
Debug.Print CStr(xyz)
End If
Next
End Function
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.