複数のExcelファイルのシートを1つのExcelブックへ集約していく、PowerShellのサンプルコードを紹介します。
仕様
サンプルとして、以下のようなExcelファイル3つを用意します。
これら3ブックにあるシートを、新しいブックのAllSheets.xlsxにコピーします。
Book1.xlsx
data:image/s3,"s3://crabby-images/e6af8/e6af84cf03687234eab899eac0f1ced71b818342" alt=""
Book2.xlsx
data:image/s3,"s3://crabby-images/09963/099638151af2f4321ae427bd199b7ac4dfc22fb5" alt=""
Book3.xlsx
data:image/s3,"s3://crabby-images/18b0d/18b0dcf5c84a9025df12bb0f0a4526fba70a10c9" alt=""
実行結果のイメージは以下のとおりです。
data:image/s3,"s3://crabby-images/ba9e1/ba9e1caf406b63107e0bee59581330d00f4ecd15" alt=""
絵心がなくてすみませんが・・
ソースコード
ソースは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で実行」をクリックします。
data:image/s3,"s3://crabby-images/787ab/787ab8a907b2771f48a3435396ffeec0d6d44236" alt=""
実行結果
実行後、ファイル「AllSheets.xlsx」が増えました。
data:image/s3,"s3://crabby-images/527d3/527d35b244d90f91fe093c6c260ce9ed3448eb7c" alt=""
ファイル「AllSheets.xlsx」を開くと、Book1~Book3にあったシートが全てコピーされています。
data:image/s3,"s3://crabby-images/8b16d/8b16d22033043f24e9b3f3254345361d16c40009" alt=""
参考情報
環境
下記の環境で作成・実行しております。
No. | 環境 | バージョン |
---|---|---|
1 | OS | Windows10 |
2 | PowerShell | 5.1 |
以上です。