Хорошим способом обработки файлов в целом является «FileSystemObject». Для того, чтобы сделать его доступным в VBA необходимо добавить ссылку на него:
(выберите меню Инструменты \ Ссылки В диалоговом окне Ссылки выберите «Microsoft выполнения сценариев».)
В следующем примере кода будет читать все файлы в папке, считывает их содержимое по одной строке за раз, разбивая каждую строку на | разделенных битов и записывает эти биты в активный лист, начиная с ячейки A1, по одной строке на строку.
Sub ReadFilesIntoActiveSheet()
Dim fso As FileSystemObject
Dim folder As folder
Dim file As file
Dim FileText As TextStream
Dim TextLine As String
Dim Items() As String
Dim i As Long
Dim cl As Range
' Get a FileSystem object
Set fso = New FileSystemObject
' get the directory you want
Set folder = fso.GetFolder("D:\YourDirectory\")
' set the starting point to write the data to
Set cl = ActiveSheet.Cells(1, 1)
' Loop thru all files in the folder
For Each file In folder.Files
' Open the file
Set FileText = file.OpenAsTextStream(ForReading)
' Read the file one line at a time
Do While Not FileText.AtEndOfStream
TextLine = FileText.ReadLine
' Parse the line into | delimited pieces
Items = Split(TextLine, "|")
' Put data on one row in active sheet
For i = 0 To UBound(Items)
cl.Offset(0, i).Value = Items(i)
Next
' Move to next row
Set cl = cl.Offset(1, 0)
Loop
' Clean up
FileText.Close
Next file
Set FileText = Nothing
Set file = Nothing
Set folder = Nothing
Set fso = Nothing
End Sub
суб сознательно упрощены, чтобы оставаться ясным (я надеюсь) и нужно работать, чтобы быть надежной (например, добавить обработку ошибок)
Объединить их первым и импортировать результат? –