我是一名新程序员,我正在尝试找到一种方法来从多个工作簿中提取一系列数据并将它们复制到主文件中。我已经在下面编写了执行此操作的代码,但我遇到的问题是我的代码物理打开 xlsm 文件 > 复制数据 > 然后返回到主文件进行粘贴。由于这是一次对数千个文件执行此操作,因此需要数小时才能完成。我的老板告诉我,如果文件被读取为 xml 或 .txt 文件,有一种方法可以从 xlsm 文件中复制数据,而无需代码实际打开文件。我在网上搜索过这个,但找不到任何关于如何做到这一点的信息。任何帮助将不胜感激。
我拥有的实际打开工作簿的代码:
Option Explicit
Sub ReadDataFromCloseFile()
On Error GoTo ErrHandler
Application.EnableEvents = False
Application.ScreenUpdating = False
Dim FileType As String
Dim FilePath As String
FileType = "*.xlsm*" 'The file type to search for
FilePath = "C:\Users\hasib\xlsm's\" 'The folder to search
Dim src As Workbook
Dim OutputCol As Variant
Dim Curr_File As Variant
OutputCol = 9 'The first row of the active sheet to start writing to
Curr_File = Dir(FilePath & FileType)
Do Until Curr_File = ""
' OPEN THE SOURCE EXCEL WORKBOOK IN "READ ONLY MODE".
Set src = Workbooks.Open(FilePath & Curr_File, True, True)
Sheets("Reporting").Range("I7:I750").Copy
Workbooks("Master.xlsm").Activate
Sheets("Sheet2").Select
Sheets("Sheet2").Cells(4, OutputCol).Select
ActiveCell.PasteSpecial Paste:=xlPasteValuesAndNumberFormats
Application.CutCopyMode = False
OutputCol = OutputCol + 1
' CLOSE THE SOURCE FILE.
src.Close False ' FALSE - DON'T SAVE THE SOURCE FILE.
Curr_File = Dir
Loop
Set src = Nothing
Application.EnableEvents = True
Application.ScreenUpdating = True
ErrHandler:
Application.EnableEvents = True
Application.ScreenUpdating = True
End Sub