Рассмотрим пример макроса, который может искать данные по многим рабочим книгам и записывать выбранную информацию в отдельный файл-отчет.
Для этого откройте свою книгу, перейдите в
Sub Report_file()
'moonexcel.com.ua
Application.ScreenUpdating = False ' отключаем обновление экрана
Set report = Workbooks("Report.xlsb").Worksheets(1)
find_field = report.[a1]
' вызываем диалог выбора файлов для импорта
FilesToOpen = Application.GetOpenFilename _
(FileFilter:="All files (*.*), *.*", _
MultiSelect:=True, Title:=" Выберите файлы! ")
If TypeName(FilesToOpen) = "Boolean" Then
MsgBox " Не выбран файл! "
Exit Sub
End If
' перебираем поочередно все выбранные файлы
m = 1
While m <= UBound(FilesToOpen)
Set importWB = Workbooks.Open(Filename:=FilesToOpen(m))
Set importWS = importWB.Worksheets(1)
' перебиоем ячейки " шапки "
For Each cell2 In report.Range(report.Cells(1, 2), report.Cells(1, report.UsedRange.Columns.Count))
On Error Resume Next: Err.Clear
' ищем значение в открытой книге
tr = importWS.UsedRange.Find(find_field).Row
tc = importWS.UsedRange.Find(find_field).Column
x = importWS.Range(importWS.Cells(tr, tc), importWS.Cells(20000, tc)).Find(report.Cells(m + 1, 1).Value).Row
y = importWS.UsedRange.Find(cell2.Value).Column
' переносим найденные значения в файл-отчет
report.Cells(m + 1, cell2.Column).Value = importWS.Cells(x, y).Value
Next
importWB.Close savechanges:=False
m = m + 1
Wend
Application.ScreenUpdating = True
End Sub
После этого можете вернуться в Excel и запустить наш макрос через меню