9

我正在使用该方法从ADODB记录集中更新一个 excel 表。CopyFromRecordset

更新后,只要有数字列,数字就会显示为日期。

到目前为止,我使用的解决方法是通过VBA将列格式化回数字,但这不是一个好的解决方案,因为报告需要更多时间才能完成。我还必须编写代码来容纳很多表。

有快速修复吗?任何帮助是极大的赞赏。

'Delete old data and copy the recordset to the table
Me.ListObjects(tblName).DataBodyRange.ClearContents
Me.Range(tblName).CopyFromRecordset rst

tblName- 指一个现有的表,该表包含与第一个数据相同的格式/数据类型的数据

4

4 回答 4

3

我知道这是一个迟到的答案,但我遇到了同样的错误。我想我找到了解决方法。

Excel 似乎希望范围是左上角的单元格而不是单元格范围。所以只需将您的声明修改为Range(tblName).Cells(1,1).CopyFromRecordset rst

'Delete old data and copy the recordset to the table
Me.ListObjects(tblName).DataBodyRange.ClearContents
Me.Range(tblName).Cells(1,1).CopyFromRecordset rst

似乎还要求目标工作表处于活动状态,因此您可能必须先确保工作表处于活动状态,然后再更改回以前活动的工作表。这可能已在更高版本的 Excel 中修复。

于 2016-10-20T08:06:50.453 回答
2

试试这个 - 这会将结果集复制到一个数组中,将其转置,然后将其复制到 excel 中

Dim rs As New ADODB.Recordset

Dim targetRange As Excel.Range

Dim vDat As Variant

' Set rs

' Set targetRange   

rs.MoveFirst

vDat = Transpose(rs.GetRows)

targetRange.Value = vDat


Function Transpose(v As Variant) As Variant
    Dim X As Long, Y As Long
    Dim tempArray As Variant

    ReDim tempArray(LBound(v, 2) To UBound(v, 2), LBound(v, 1) To UBound(v, 1))
    For X = LBound(v, 2) To UBound(v, 2)
        For Y = LBound(v, 1) To UBound(v, 1)
            tempArray(X, Y) = v(Y, X)
        Next Y
    Next X

    Transpose = tempArray

End Function
于 2013-10-22T15:36:04.677 回答
1

下面是示例代码。每当调用 proc getTableData 时,都会根据记录集保留 table1 的格式和列格式。我希望这就是你要找的。

 Sub getTableData()

    Dim rs As ADODB.Recordset
    Set rs = getRecordset

    Range("A1").CurrentRegion.Clear
    Range("A1").CopyFromRecordset rs
    Sheets("Sheet1").ListObjects.Add(xlSrcRange, Range("A1").CurrentRegion, , xlNo).Name = "Table1"

End Sub



Function getRecordset() As ADODB.Recordset

    Dim rsContacts As ADODB.Recordset
    Set rsContacts = New ADODB.Recordset

    With rsContacts
        .Fields.Append "P_Name", adVarChar, 50
        .Fields.Append "ContactID", adInteger
        .Fields.Append "Sales", adDouble
        .Fields.Append "DOB", adDate
        .CursorLocation = adUseClient
        .CursorType = adOpenStatic

        .Open

        For i = 1 To WorksheetFunction.RandBetween(3, 5)
             .AddNew
            !P_Name = "Santosh"
            !ContactID = 2123456 * i
            !Sales = 10000000 * i
            !DOB = #4/1/2013#
            .Update
        Next

        rsContacts.MoveFirst
    End With

    Set getRecordset = rsContacts
End Function

在此处输入图像描述

于 2013-04-18T03:28:04.007 回答
0

在阅读了遇到相同问题的其他人的论坛帖子后,以下是我所知道的所有选项(其中一些已经在其他答案中提到):

  1. 仅插入目标范围的第一个单元格 - 请参阅@ThunderFrame 的答案。
  2. 在上面的行中激活包含目标范围的工作表CopyFromRecordset()
  3. 关闭自动重新计算:

    Application.Calculation = xlCalculationManual
    .CopyFromRecordset rs
    Application.Calculation = xlCalculationAutomatic
    

解决方法:

  1. 迭代行/列并一次插入一个值-@Sriketan 的答案为此提供了代码。另一个代码片段在下面的链接中。
  2. 粘贴到临时工作簿中,然后从那里复制。

资料来源:

  1. Duchgemini 的帖子和讨论:https ://dutchgemini.wordpress.com/2011/04/21/two-serious-flaws-with-excels-copyfromrecordset-method/
  2. 微软论坛:https ://social.msdn.microsoft.com/Forums/office/en-US/129c0a52-4ccb-4f54-9e38-8c0ae6e300b1/copyfromrecordset-corrupts-cell-formats-for-the-whole-excel-workbook ?forum=exceldev
于 2019-04-05T09:26:22.703 回答