HOME > 即効テクニック > Excel VBA > セル操作関連のテクニック > セルのスタイルを参照する(Styleプロパティ)

即効テクニック

セル操作関連のテクニック

セルのスタイルを参照する(Styleプロパティ)

(Excel 2000)

対象のセル範囲のスタイルを表すStyleオブジェクトを参照します。スタイルとは、セルの書式設定に関するプロパティやオブジェクトの「ある状態」に名前を付けて管理しているもの、と考えれば良いでしょう。従って、同じ書式を複数のセル範囲で共通して使用したい場合には、新しくStyleオブジェクトを登録して使用すれば効率の良いプログラミングが可能です。

 構文 Object.Style 取得のみ  設定項目 内容 Object Range, Workbookオブジェクト 次のサンプルは、新しく「見出し」というスタイルを作成し、セルに適用しています。
●サンプル●
Sub StyleSamp1()

  Dim s As Style
  Dim myStyle As Style

  For Each s In ActiveWorkbook.Styles '---(1)登録されているかどうか検査
      If s.Name = "見出し" Then _
          Set myStyle = s              '---既に登録されていた場合
  Next s
  If myStyle Is Nothing Then _
      Set myStyle = ActiveWorkbook.Styles. _
                    Add(Name:="見出し")   '---未登録の場合、追加
  With myStyle     '(2)---スタイルの内容を定義していきます
      .Interior.ColorIndex = 1
      With .Font
          .ColorIndex = 2
          .Size = 20
          .Bold = False
          .Name = "HGS創英角ポップ体"
      End With
       .NumberFormatLocal = "@"
  End With
  Range("A1").Style = "見出し"   '----(3)セルA1に追加したスタイルを適用
  Range("A1").Value = Range("A1").Style.Name
  Range("A2").Value = Range("A2").Style.Name      '----(4)
  Range("A3").Value = Range("A3").Style.NameLocal '----(5)
End Sub
StyleオブジェクトはRangeオブジェクトの下位オブジェクトですが、ワークブック単位で管理されているため、Workbookオブジェクトを対象としたときのStyleプロパティは、スタイルのコレクションであるStylesコレクションを参照します。従って、(1)以下のような記述となります。(2)でスタイルの内容を登録していますが、ここに記述している以外にも、ほとんどのセルの書式設定に関わるプロパティやオブジェクトについての設定が可能です。Styleを登録したことにより、今後は同じワークブックであれば、どのシートのセル範囲に対しても、(3)のような簡単なステートメントで書式を共有することができます。
ちなみに、(4)と(5)で「標準」スタイルの名前をセルに書き出しているのですが、NameプロパティとNameLocalプロパティでは結果が異なります。ご注意ください。