首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用VBA在SAP中使用导出的数据作为输入

如何使用VBA在SAP中使用导出的数据作为输入
EN

Stack Overflow用户
提问于 2022-09-07 06:32:24
回答 1查看 59关注 0票数 -1

我正在写一个VBA脚本来检查所有的测量点,谁是选择的一部分有检查命令。为此,我需要提取大量的度量点(约2721),并将它们用作另一个事务中的输入。

我遇到的问题是:从SAP中提取/导出大量数据的最有效方式是什么,我可以将它们作为SAP中的输入来粘贴?

我可以进行导出,但不能通过VBA访问导出的Excel文件.我可以循环遍历数据并复制每个单元格,但是这非常慢,如下所示。

代码语言:javascript
复制
row = 1
For i = 1 To session.FindById("wnd[0]/usr/cntlGRID1/shellcont/shell").RowCount - 2
    session.FindById("wnd[0]/usr/cntlGRID1/shellcont/shell").CurrentCellRow = i    
    ThisWorkbook.Sheets("Output2").Cells(row, 1) = session.FindById("wnd[0]/usr/cntlGRID1/shellcont/shell").GetCellValue(i - 1, "TPLNR")
    ThisWorkbook.Sheets("Output2").Cells(row, 2) = session.FindById("wnd[0]/usr/cntlGRID1/shellcont/shell").GetCellValue(i - 1, "POINT")
    row = row + 1
Next
EN

回答 1

Stack Overflow用户

发布于 2022-09-07 06:48:30

你应该

  • 使用数组-而不是直接写入表
  • 使用with不多次调用session.FindByID...

代码语言:javascript
复制
Dim arrData As Variant, i As Long

With session.FindById("wnd[0]/usr/cntlGRID1/shellcont/shell")
    
    ReDim arrData(1 To .RowCount - 2, 1 To 2)
    
    For i = 1 To .RowCount - 2
        .CurrentCellRow = i
        arrData(i, 1) = .GetCellValue(i - 1, "TPLNR")
        arrData(i, 2) = .GetCellValue(i - 1, "POINT")
    Next
    
End With

With ThisWorkbook.Sheets("Output2")
    .Resize(UBound(arrData, 1), 2).Value = arrData
End With

但是,也许研究Powerquery来实现您想要的结果是值得的。

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

https://stackoverflow.com/questions/73631017

复制
相关文章

相似问题

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