如何在VB中连接两个多维数组?

Posted

技术标签:

【中文标题】如何在VB中连接两个多维数组?【英文标题】:How do I concatenate two multi-dimensional arrays in VB? 【发布时间】:2010-09-15 13:12:01 【问题描述】:

我有这个代码:

rs1 = getResults(sSQL1)
rs2 = getResults(sSQL2)

rs1 和 rs2 以及二维数组。第一个索引表示列数(静态),第二个索引表示行数(动态)。

我需要加入这两个数组并将它们存储在 rs3 中。我不知道 rs1 和 rs2 是什么类型。

【问题讨论】:

【参考方案1】:

您确定这些列会匹配吗?因为如果不是这种情况,我不知道您将如何以任何语言以通用方式进行操作。如果是这种情况,那么您可能会非常这样做:

rs1 = getResults(sSQL1 & " UNION " sSQL2)

【讨论】:

是的,我确定。它们都在执行相同的存储过程(我知道,但不是我写的,我只需要维护它)【参考方案2】:

我想通了。事实证明我一直都在做正确的事情,我只差一个。你也不需要第三个数组。

        aRS_RU = rowsQuery(sSQL & ", 'RU'")
        aRS_KR = rowsQuery(sSQL & ", 'KR'")

        uboundRU1 = UBound(aRS_RU, 1)
        uboundRU2 = UBound(aRS_RU, 2)
        uboundKR2 = Ubound(aRS_KR, 2)

        ' Redim original array
        ReDim Preserve aRS_RU(uboundRU1, uboundRU2 + uboundKR2 + 1 )
        uboundRU2 = UBound(aRS_RU, 2)

        ' Add the values from the second array            
        For m = LBound(aRS_KR, 1) To UBound(aRS_KR, 1)      'Loop for 1st dimension
            For n = LBound(aRS_KR, 2) To UBound(aRS_KR, 2)  'Loop for 2nd dimension
                aRS_RU(m, uboundRU2 + n) = aRS_KR(m,n)
            Next
        Next           

【讨论】:

【参考方案3】:

我知道这篇文章很旧,但我修改了代码以修复我在执行过程中遇到的一些错误。以下代码示例适用于我:

Sub ConcatRecordSets(ByRef avFirstRS As Variant, ByRef avSecondRS As Variant)

    Dim lIndex1 As Long, lIndex2 As Long
    Dim lFirstRSSize As Long, lSecondRSSize As Long

    ' Redim original array
    lFirstRSSize = UBound(avFirstRS, 2) - LBound(avFirstRS, 2) + 1
    lSecondRSSize = UBound(avSecondRS, 2) - LBound(avSecondRS, 2) + 1
    ReDim Preserve avFirstRS(LBound(avFirstRS, 1) To UBound(avFirstRS, 1), LBound(avFirstRS, 2) To UBound(avFirstRS, 2) + lSecondRSSize)

    ' Add the values from the second array
    For lIndex1 = LBound(avSecondRS, 1) To UBound(avSecondRS, 1)      ' Loop for 1st dimension
        For lIndex2 = LBound(avSecondRS, 2) To UBound(avSecondRS, 2)  ' Loop for 2nd dimension
            avFirstRS(lIndex1, lFirstRSSize + lIndex2) = avSecondRS(lIndex1, lIndex2)
        Next lIndex2
    Next lIndex1

End Sub

【讨论】:

为什么不直接使用 Array.Resize + Array.Copy?

以上是关于如何在VB中连接两个多维数组?的主要内容,如果未能解决你的问题,请参考以下文章

连接两个单维列表以获得一个多维列表

如何使用 laravel 将多维数组传递给 API

如果数组存在于另一个多维数组中,如何从多维数组中删除该数组? [复制]

C,如何将多维数组传递给 CLR/类库项目中的函数

如何比较两个PHP多维数组

在 PHP 中执行数组交集时如何保留多维数组信息?