サイトについて      連絡先   検索

VBA セルに値を設定する

はじめに

Excel VBA マクロのセルに値を設定する方法を紹介します。

Range.Value プロパティまたは Cells.Value プロパティでセルに値を設定できます。

Worksheets から指定したシートのセルに値を設定できます。

  • 目次
    • セルに値を設定する
    • セルの範囲に値を設定する
    • 指定したシートのセルに値を設定する

セルに値を設定する

Range の引数にセル名を指定すると、そのセルに値を設定できます。

セル「A1」に値を設定するにはRange("A1").Valueを入力します。


Range("A1").Value = "マクロ"
Range("B1").Value = 123
Range("C1").Value = Now
4

Cells の引数にセルの行と列の番号を指定すると、そのセルに値を設定できます。

行「2」、列「A」に値を設定するにはCells(2, 1).Valueを入力します。


Cells(1, 1).Value = "A1"
Cells(2, 1).Value = "A2"
Cells(1, 2).Value = "B1"
Cells(2, 2).Value = "B2"

セルの範囲に値を設定する

セルの範囲「A1」~「B2」に同じ値を設定するにはRange("A1:B2").ValueまたはRange("A1", "B2").Valueを入力します。


Range("A1:B2").Value = "マクロ"
Range("A1", "B2").Value = "マクロ"
1

セルの範囲に別々の値を設定するには (行, 列) の二次元配列を設定します。


Dim s(1, 1) As String
s(0, 0) = "A1"
s(1, 0) = "A2"
s(0, 1) = "B1"
s(1, 1) = "B2"
Range("A1:B2").Value = s
2

二次元配列がどのような形になっているのかイメージできれば、そのままセルに設定されているのがわかります。

二次元配列の最小インデックスはいくつでも構いません。自動で対応します。


Dim s(1 To 2, 1 To 2) As String
s(1, 1) = "A1"
s(2, 1) = "A2"
s(1, 2) = "B1"
s(2, 2) = "B2"
Range("A1:B2").Value = s
2

セルの範囲の値をまとめて取得または設定すると高速に操作できます。

行に設定するときは二次元配列でも一次元配列でも設定できます。


Dim s(0, 2) As String ' 二次元配列
s(0, 0) = "A"
s(0, 1) = "B"
s(0, 2) = "C"
Range("A2:C2").Value = s

Dim s(2) As String ' 一次元配列
s(0) = "A"
s(1) = "B"
s(2) = "C"
Range("A2:C2").Value = s
3

列に設定するときは二次元配列の列を 0 にします。


Dim s(2, 0) As String ' (行, 列)
s(0, 0) = "A1"
s(1, 0) = "A2"
s(2, 0) = "A3"
Range("A1:A3").Value = s

指定したシートのセルに値を設定する

シートを指定するには Worksheets の引数にシート名またはインデックスを指定します。

Sheet1 を指定するにはWorksheets("Sheet1")またはWorksheets(1)を入力します。

sheet1

' Sheet1 のセル「A1」に値を設定
Worksheets("Sheet1").Range("A1").Value = "Sheet1 の A1"
Worksheets(1).Range("A1").Value = "Sheet1 の A1"

' Sheet2 のセル「A1」に値を設定
Worksheets("Sheet2").Range("A1").Value = "Sheet2 の A1"
Worksheets(2).Range("A1").Value = "Sheet2 の A1"

Sheet1 に Range や Cells を入力すると、自身のシートのセルになります。自身を表すMe.が省略されています。


' どちらも同じコード
Range("A1").Value = "Sheet1"
Me.Range("A1").Value = "Sheet1"

標準モジュールに Range や Cells を入力すると、アクティブなシートのセルになります。アクティブシートを表すActiveSheet.が省略されています。


' どちらも同じコード
Range("A1").Value = "アクティブ"
ActiveSheet.Range("A1").Value = "アクティブ"
  • 目次
    • セルに値を設定する
    • セルの範囲に値を設定する
    • 指定したシートのセルに値を設定する