2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

複数のCSVを1つにまとめるVBAを作ってみた

Last updated at Posted at 2020-06-15

1. 背景

 Excelで複数のCSVファイルを一つにまとめたいと思ったのですが、簡単にできそうな方法がなかったので、VBAでCSVを結合するツールを作ってみました。

2. ソースコード

 取り敢えず、下記のコードをコピペすれば動作するはずです。素人のコードですので、読みづらい点はご容赦ください。

Sub Main()
    Dim SelectedFiles As Variant '入力ファイル名の一覧
    Dim inputfile As String '入力ファイル名
    Dim OutputWB As Workbook '結合データ記入用ワークブック
    
    Set OutputWB = Workbooks.Add
    
    'エクスプローラーを起動し、ファイルを選択
    SelectedFiles = Application.GetOpenFilename("CSVファイル(*.csv),*.csv", MultiSelect:=True)
    
    'シートの枚数を確認
    Call CheckSheets(OutputWB)
    
    'CSVを読み込む
    Call ReadCSV(SelectedFiles, OutputWB)
End Sub

Private Sub CheckSheets(ByVal wb As Workbook)
    'シート数を二枚にする
    If wb.Worksheets.Count = 1 Then
        wb.Worksheets.Add
    End If
    'シート名称を変更
    wb.Worksheets(1).Name = "データ"
    wb.Worksheets(2).Name = "入力ファイル一覧"
End Sub

Private Sub ReadCSV(ByRef datafiles As Variant, ByVal wb As Workbook)
    Dim filecounter As Integer, arraycounter As Integer, rowcounter As Integer
    Dim buf As String
    Dim tmp As Variant, inputfile As Variant
    
    filecounter = 1
    rowcounter = 1
    For Each inputfile In datafiles
        wb.Worksheets(2).Cells(filecounter, 1).Value = inputfile
        Open inputfile For Input As #1
        If filecounter > 1 Then
            'ヘッダ分を読み込む
            Line Input #1, buf
        End If
        Do Until EOF(1)
            '一行分を読み込む
            Line Input #1, buf
            '区切り文字で分割する
            tmp = Split(buf, ",")
            For arraycounter = 1 To UBound(tmp)
                wb.Worksheets(1).Cells(rowcounter, arraycounter).Value = tmp(arraycounter)
            Next
            rowcounter = rowcounter + 1
        Loop
        Close #1
        filecounter = filecounter + 1
    Next inputfile
End Sub

2-1. メイン

 このツールの処理は次の通りです。結合したいCSVファイルをエクスプローラーで選択し、新規に開いたワークブックにデータと読み込んだファイルの一覧を記入するという処理をしています。

Sub Main()
    Dim SelectedFiles As Variant '入力ファイル名の一覧
    Dim inputfile As String '入力ファイル名
    Dim OutputWB As Workbook '結合データ記入用ワークブック
    
    Set OutputWB = Workbooks.Add
    
    'エクスプローラーを起動し、ファイルを選択
    SelectedFiles = Application.GetOpenFilename("CSVファイル(*.csv),*.csv", MultiSelect:=True)
    
    'シートの枚数を確認
    Call CheckSheets(OutputWB)
    
    'CSVを読み込む
    Call ReadCSV(SelectedFiles, OutputWB)
    
End Sub

2-2. シート枚数確認用の関数

 この関数では、シート枚数を確認し、1枚であればシートを追加する。その後、シート1, 2に名前をつけるという処理をしています。

Private Sub CheckSheets(ByVal wb As Workbook)
    'シート数を二枚にする
    If wb.Worksheets.Count = 1 Then
        wb.Worksheets.Add
    End If
    'シート名称を変更
    wb.Worksheets(1).Name = "データ"
    wb.Worksheets(2).Name = "入力ファイル一覧"
End Sub

2-3. データ書き込み用の関数

 この関数では、2-2. で2枚にしたワークブックにCSVのデータとファイルの一覧を記入する処理を行います。

Private Sub ReadCSV(ByRef datafiles As Variant, ByVal wb As Workbook)
    Dim filecounter As Integer, arraycounter As Integer, rowcounter As Integer
    Dim buf As String
    Dim tmp As Variant, inputfile As Variant
    
    filecounter = 1
    rowcounter = 1
    For Each inputfile In datafiles
        wb.Worksheets(2).Cells(filecounter, 1).Value = inputfile
        Open inputfile For Input As #1
        If filecounter > 1 Then
            'ヘッダ分を読み込む
            Line Input #1, buf
        End If
        Do Until EOF(1)
            '一行分を読み込む
            Line Input #1, buf
            '区切り文字で分割する
            tmp = Split(buf, ",")
            For arraycounter = 1 To UBound(tmp)
                wb.Worksheets(1).Cells(rowcounter, arraycounter).Value = tmp(arraycounter)
            Next
            rowcounter = rowcounter + 1
        Loop
        Close #1
        filecounter = filecounter + 1
    Next inputfile
End Sub
2
2
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?