TOP

さまざまなファイルからデータを収集するスパイダー マクロ Excel

説明

この記事では、多くのブック内のデータを検索し、選択した情報を別のレポート ファイルに記録できるマクロの例を検討します。


これを行うには、本を開いて、 Visual Basic Editor (Alt+F11) 新しいモジュールを空白で追加します (Insert - Module) そして、このマクロ テキストをそこにコピーします。

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
    
    ' 選択したすべてのファイルを 1 つずつ調べます 
    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 に戻り、メニューからマクロを実行できます。 Tools - Macro - Macros (Alt+F8)