こんにちは。たいら(@tairaengineer2)です。
転職を繰り返し現在4社経験している、11年目エンジニアです。
この記事では、 RubyのrubyXLのgemを使ってエクセルファイル(xlsx)の指定したセルの文字色を変更するやり方について、
- エクセルファイル(xlsx)の指定したセルの文字色を変更するサンプルプログラム
- 実行結果
- 解説
という順番で解説していきます。
rubyXLをインストールするやり方はこちらの記事をご参考ください。
前提条件:実行環境について
実行環境は以下の通りです。
OS | Windows10 |
---|---|
Rubyのバージョン | 2.6.6 |
rubyXLのバージョン | 3.4.25 |
この記事ではRubyプログラムは
C:\rubystudy
に作成しています。
エクセルファイル(xlsx)の指定したセルの文字色を変更するサンプルプログラム
このサンプルプログラムは、
C:\rubystudy\sample\aaa
配下にある「sample.xlsx」というエクセルファイルの特定のセルのみ文字色を赤と青にします。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
require 'rubyXL' require 'rubyXL/convenience_methods' sample_xlsx = RubyXL::Workbook.new sample_worksheet = sample_xlsx[0] sample_worksheet.add_cell(0, 0, '文字色が赤') sample_worksheet.add_cell(0, 1, '文字色が青') sample_worksheet[0][0].change_font_color('FF0000') sample_worksheet[0][1].change_font_color('0000FF') sample_xlsx.write('C:/rubystudy/sample/aaa/sample.xlsx') puts "xlsx書き込み完了" |
実行結果
実行前に
C:\rubystudy\sample\aaa
の「sample.xlsx」の中を確認します。
中身が空であることを確認しました。
では、エクセルファイルの文字色を変更できるかを確認します。
Rubyプログラムを実行するやり方は、以下の記事をご参考ください。
1 2 |
C:\rubystudy>ruby workbook_font_bold_sample.rb xlsx書き込み完了 |
C:\rubystudy\sample\aaa
の「sample.xlsx」の中を確認します。
指定したセルのみ文字色を変更できていることが確認できました。
解説
サンプルプログラムから大切な点である
- requireについて
- 文字色指定について
の2点を解説していきます。
requireについて
rubyXLを使う場合は
1 |
require 'rubyXL' |
色などを指定できるメソッドを使いたい場合は
1 |
require 'rubyXL/convenience_methods' |
という宣言が必須です。
忘れないようご注意ください。
require関数については、こちらの記事をご参考ください。
文字色指定について
特定のセルに文字色を指定している箇所は
1 2 |
sample_worksheet[0][0].change_font_color('FF0000') sample_worksheet[0][1].change_font_color('0000FF') |
の部分です。
change_font_colorメソッドは、呼び出しているセルの文字色を引数のcssのカラーコード値に指定できるメソッドです。
1 |
sample_worksheet[0][1] |
で取得したシートの0行目の1列目のセル、つまりB1セルで呼び出して
1 |
.change_font_color('0000FF') |
で文字色を青に指定しています。
まとめ:rubyXLでエクセルファイル(xlsx)の指定したセルの文字色を変更してみよう
以上がRubyでrubyXLを使ってエクセルファイル(xlsx)の指定したセルの文字色を変更するやり方の解説でした!
あなたのご参考になったのなら、とても嬉しいです(*´▽`*)
ではでは~(・ω・)ノシ
コメント