Excelの各セルのフォント名(フォントファミリー)を変更するPowerShellのサンプルコードを紹介します。
仕様
ローカルの任意の場所にPowerShellの*.ps1ファイルと、Excelファイルを格納します。
data:image/s3,"s3://crabby-images/dda58/dda580ce17037ba4f1b609034aed4f49163a4e6d" alt=""
「Book1.xlsx」のA列のセルのフォント名を変更してみます。
後でPowerShellの実行前後を比較するため、B列にもA列の内容をコピーしておきます。
data:image/s3,"s3://crabby-images/dc27d/dc27d06626ae843b7b54788fb3366fc12c46aabb" alt=""
PowerShell実行前のフォント名は游ゴシックです。
これを以下のような別のフォント名に変更させます。
セル位置 | 実行前 | 実行後 |
---|---|---|
A1 | 游ゴシック | MS Pゴシック |
A2 | 游ゴシック | MS ゴシック |
A3 | 游ゴシック | MS 明朝 |
A4 | 游ゴシック | メイリオ |
A5 | 游ゴシック | 游ゴシック |
ソースコード
以下のコマンドとps1ファイルを準備しておきます。
コマンド
powershell -ExecutionPolicy RemoteSigned -File "setExcelFontName.ps1"
setExcelFontName.ps1
$excel = New-Object -ComObject Excel.Application
$book = $null
$excel.Visible = $false
$excel.DisplayAlerts = $false
$fileName = "Book1.xlsx"
$filePath = (Convert-Path .) + "/" + $fileName
$book = $excel.Workbooks.Open($filePath)
$sheet = $book.Sheets("Sheet1")
$cell = $sheet.Cells(1,1)
$cell.font.Name = "MS Pゴシック"
$cell = $sheet.Cells(2,1)
$cell.font.Name = "MS ゴシック"
$cell = $sheet.Cells(3,1)
$cell.font.Name = "MS 明朝"
$cell = $sheet.Cells(4,1)
$cell.font.Name = "メイリオ"
$cell = $sheet.Cells(5,1)
$cell.font.Name = "游ゴシック"
[void]$book.Save()
[void]$book.Close($false)
[void][System.Runtime.Interopservices.Marshal]::ReleaseComObject($book)
[void]$excel.Quit()
[void][System.Runtime.Interopservices.Marshal]::ReleaseComObject($excel)
Pause
実行
実行手順
Windows PowerShellのターミナルからsetExcelFontName.ps1を実行するコマンドを打ちます。
data:image/s3,"s3://crabby-images/f71a6/f71a64b2b51402a01cb0dfc89c37595114219115" alt=""
実行結果
以下の通り、ExcelファイルのA列のフォント名が変わりました。
data:image/s3,"s3://crabby-images/c03b6/c03b6225583f55b807a6f865f08850c2c5fbcd0e" alt=""
見た目だけでもフォントが変更されたことが分かります。
ただ本当に変更されているか、各セルにフォーカスを当てて確認しました。
data:image/s3,"s3://crabby-images/e594a/e594a77b04cc8b2a47829f21c3a5388086ab4063" alt=""
data:image/s3,"s3://crabby-images/369cd/369cdc2c156203904cc5084f3acc5e0f15efd493" alt=""
data:image/s3,"s3://crabby-images/44c8d/44c8d0d57f264e7a48f74f0a89b88bfe4da1bcd3" alt=""
data:image/s3,"s3://crabby-images/ad089/ad0892ec3af94e6335947dbb8cd924c7c1c36097" alt=""
data:image/s3,"s3://crabby-images/3256f/3256f61367f205d8fd09368b426e14ac59fa769c" alt=""
参考情報
環境
下記の環境で作成・実行しております。
No. | 環境 | バージョン |
---|---|---|
1 | OS | Windows11 |
2 | PowerShell | 5.1 |
以上です。