【ExcelVBA入門】セルの値を取得・設定・クリアする方法を徹底解説!

こんにちは、フリーランスエンジニア兼ライターのワキザカ サンシロウです。

皆さんは、VBAセルの値を操作する方法を知っていますか?

Excelはセルのデータできているため、セル操作はVBAを書く上で肝となる機能です。

そこで今回は、セルを指定する方法や、値を取得・設定する方法といった基礎的なことから、

  • セルの値をクリアする方法
  • セルの値を変数にセットする方法
  • 合わせて覚えると便利な一覧データの範囲指定方法

といった応用的な方法まで、徹底的に解説します!

セルを指定する方法

はじめに、セルの値を指定する方法について解説します。

Rangeプロパティを使う方法

まず、Rangeメソッドを使った指定方法について解説します。

Rangeメソッドは次のように使います。

使い方:

Range(セルのアドレス)

A1、B2、C5のようなセルのアドレスをRangeの引数に入れることで、セルの位置を指定することができます。セルのアドレスを直接指定するので、直感的でわかりやすいですよね。

ちなみに、Rangeメソッドの詳しい使い方については以下でも解説しているので、気になる方は見てみてくださいね!

【VBA入門】Rangeでセルの範囲指定(Cellsとの使い分けも解説)
更新日 : 2019年9月26日

Cellsプロパティを使う方法

次に、Cellsメソッドを使った指定方法について解説します。

Cellsメソッドは次のように使います。

使い方:

Cells(行番号 , 列番号)

1、3、4、7のように数値を行番号・列番号に入れることで、セルの位置を指定することができます。

番号で行・列を指定することができるので、「データの行数分ループ処理を実行する」ようなVBAの処理を作るときに、行番号を増やしていくだけで処理を作れるため、覚えておくと便利です。

ちなみに、Cellsメソッドの詳しい使い方については以下でも解説しているので、気になる方は見てみてくださいね!

【VBA入門】Cellsでセルを指定(変数などRangeとの使い分けも解説)
更新日 : 2020年3月24日

シートを指定してセルの値を指定する方法

ここまで解説したRange・Cellsはセルの位置を指定する方法でしたが、Excelはセル以外にも「シート」がありますよね。

次に、シートを指定したセルの指定方法について解説します。

シートの指定方法は大きく分けて3つあります。

シートの指定方法:

Activesheet.Range
Worksheets(シート番号).Range
Worksheets(シート名).Range

Activesheetは現在選択しているシートを指定でき、Worksheetsはシート番号・シート名でシートを指定することができます。

アクティブシート・その他のシート操作については以下で詳しく解説しているので、気になる方は見てみてくださいね!


【VBA入門】WorksheetsからWorksheetオブジェクトを取得し操作する
更新日 : 2019年4月24日

セルの値を操作する方法

次に、セルの値を操作する方法について解説します。

セルの値を取得・設定する方法

まずは、セルの値を取得・設定する方法について解説します。

Valueプロパティを使って簡単に取得・設定をすることができます。

使い方:

'値を取得する場合
Range(セルのアドレス).Value
Cells(行番号 , 列番号).Value

'値を設定する場合
Range(セルのアドレス).Value = 設定する値
Cells(行番号 , 列番号).Value = 設定する値

セルのデータを使うケース・データを書き込むケースはよくあるので、覚えておくと便利です!

Valueプロパティを使ったセルの値取得・設定方法については、以下で詳しく解説しているので見てみてくださいね!

【ExcelVBA】セルの値を取得・書き込むためのValueプロパティとは?
更新日 : 2019年7月9日

セルの値をクリアする方法

次に、セルの値をクリアする方法について解説します。

Clearメソッドを使って、簡単にクリアをすることができます。

使い方:

Range(セルのアドレス).Clear
Cells(行番号 , 列番号).Clear

データを一度クリアしてから再度処理をするケースはよくあるので、覚えておくと便利です!

セルをクリアする方法については以下で詳しく解説しているので、気になる方は見てみてくださいね!

【ExcelVBA入門】セルをクリアする方法について徹底解説!
更新日 : 2018年10月22日

セルの値を変数にセットする方法

次に、セルの値を変数にセットする方法について解説します。

次のように書くことで、変数に値をセットすることができます。

使い方:

Dim 変数名1 As 型名
変数名1 = Range(セルのアドレス).Value

Dim 変数名2 As 型名
変数名2 = Cells(行番号 , 列番号).Value

変数に値をセットして使うケースは多いので、覚えておくと便利です!

変数の使い方については以下で詳しく解説しているので、気になる方は見てみてくださいね!

【VBA入門】変数をDimで宣言し、 Asでデータ型を定義する方法
更新日 : 2019年10月1日

合わせて覚えると便利なセルの指定方法

ここまでセルを指定して操作する方法について解説してきましたが、データ一覧をまとめて操作したいケースもありますよね。

そんな時に便利なのが、UsedRangeプロパティです。

UsedRangeプロパティを使えば、簡単にデータ一覧のセル範囲を取得することができます。

実行前のデータ:

サンプルコード:

Sub Test5()
  ActiveSheet.UsedRange.Clear
End Sub

実行結果:

「ActiveSheet」で表示しているシート・「UsedRange」ですべてのデータ範囲を指定し、データをクリアするサンプルです。

データ一覧のデータを指定して操作するケースはよくあるので、覚えておくと便利です!

UsedRangeプロパティの詳しい使い方については以下で解説しているので、見てみてくださいね!

【ExcelVBA】UsedRangeプロパティでセル範囲を全て取得する方法とは?
更新日 : 2019年5月25日

まとめ

今回は、VBAでセルの値を指定して操作する方法について徹底的に解説しました。

Excelはセルのデータが集まったデータを操作するソフトなので、セルの値を操作する方法は覚えておくと便利です。

使い方も簡単なので、ぜひ使ってみてくださいね!

「プログラミング、右も左もわからない…」という方にオススメ

cta_under_bnr

当プログラミングスクール「侍エンジニア」では、これまで6000人以上のエンジニアを輩出してきました。

その経験を通してプログラミング学習に成功する人は、「目的目標が明確でそれに合わせた学習プランがあること」「常に相談できる人がそばにいること」「自己解決能力が身につくこと」この3つが根付いている傾向を発見しました。

侍エンジニアは上記3つの成功ポイントを満たすようなサービス設計に磨きをかけております。

cta_under_bnr

「自分のスタイルや目的に合わせて学習を進めたいな」とお考えの方は、ぜひチェックしてみてください。

詳細はこちら

書いた人

Sanshiro Wakizaka

北海道出身の30歳で、フリーランスエンジニア兼テックライターとして活動中。新卒入社したメーカー系のIT企業で、システムエンジニアとして約5年勤務。

Webアプリ、業務アプリ開発において、要件定義 ~ 運用保守まで様々な経験あり。また3歳の娘がいる1児のパパで、日々娘との時間を確保するために仕事を頑張っています!

侍エンジニアでは、【誰でもわかるレベルのわかりやすさ】を意識して、記事を執筆中。

おすすめコンテンツ

まずはここから!初心者でも1から学べるプログラミング入門カリキュラム

転職成功で受講料0円!あなたもプログラミングを学んでエンジニアデビュー