複数のExcelファイルのシートを1つのExcelブックへコピーしていくPowerShellのサンプルコード

PowerShell
記事内に広告が含まれています。

複数のExcelファイルのシートを1つのExcelブックへ集約していく、PowerShellのサンプルコードを紹介します。

仕様

サンプルとして、以下のようなExcelファイル3つを用意します。

これら3ブックにあるシートを、新しいブックのAllSheets.xlsxにコピーします。

Book1.xlsx

Book2.xlsx

Book3.xlsx

実行結果のイメージは以下のとおりです。

絵心がなくてすみませんが・・

ソースコード

ソースはPowerShellで記述します。

createAllBookSheets.ps1

$excel = New-Object -ComObject Excel.Application
$book = $null

$excel.Visible = $false
$excel.DisplayAlerts = $false

# 出力先ファイル
$destFilePath = (Convert-Path .) + "\AllSheets.xlsx"
$destBook = $excel.Workbooks.add()

# 入力元ファイル
$sourceFiles = Get-Item *.xlsx

foreach($item in $sourceFiles){
    $sourceBook = $excel.Workbooks.Open($item)

    foreach($s in $sourceBook.sheets){
        $sourceBook.Worksheets.item($s.Name).copy([System.Reflection.Missing]::Value,$destBook.Worksheets.item($destBook.worksheets.count))
    }

    [void]$sourceBook.Close($false)
    [void][System.Runtime.Interopservices.Marshal]::ReleaseComObject($sourceBook)

}

# AllSheetsの初期シートは削除
$destBook.Worksheets.item(1).delete()

[void]$destBook.SaveAs($destFilePath)

[void]$destBook.Close($false)
[void][System.Runtime.Interopservices.Marshal]::ReleaseComObject($destBook)

[void]$excel.Quit()
[void][System.Runtime.Interopservices.Marshal]::ReleaseComObject($excel)

Pause

1つ目のforeach文で、*.xlsxファイルを開いていきます。
2つ目のforeach文で、各シートを開きファイル「AllSheets.xlsx」にコピーしていきます。

実行

実行手順

では上記のPowerShellを実行します。

実行は右クリックメニューの「PowerShellで実行」をクリックします。

実行結果

実行後、ファイル「AllSheets.xlsx」が増えました。

ファイル「AllSheets.xlsx」を開くと、Book1~Book3にあったシートが全てコピーされています。

参考情報

環境

下記の環境で作成・実行しております。

No.環境バージョン
1OSWindows10
2PowerShell5.1
環境一覧

以上です。