ExcelマクロVBA技術解説 | 空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula) | Excelマクロの問題点と解決策、エクセルVBAの技術的解説



最終更新日:2015-02-16

空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)


空白セルの判定は、ExcelマクロVBAにおいては度々発生しますが、

正しく空白セルを判定する事は以外と難しいものです。

以下、A1セルが空白かどうか判定する方法をいくつか紹介します。

If Cells(1, 1) = "" Then
  '空白
End If
または、
If Len(Cells(i, 1)) = 0 Then
  '空白
End If


普通に、= ""が最も簡単です。

わざわざLen関数を使っているのを、ネットでは割と多く見かけます。

恐らく、VB等の記述からきているのでしょうが、

VBAでは特に使う必要性はないように思います。

では、これで空白セルの判定は終わりでしょうか・・・

それでは、この記事の意味がありませんね。(笑)

もし、A1セルに関数が入っていて、その結果が空白の場合です。

この場合に、空白セルと判定したくない場合です。

これは良くある事です。

上記のIfでは、空白と判定されてしまいますので、

何らかの対策が必要になります。

If Not Cells(i, 1).HasFormula Then
  If Cells(1, 1) = "" Then
    '空白
  End If
End If


HasFormulaは、数式が入力されている場合は、Trueが返ります。

つまり、数式が入力されていない状態で、""なら空白と判断しています。

これで大抵の場合はOKでしょう。

しかし、もし、セル値が、エラー値の場合はどうでしょう・・・

通常は、数式の結果がエラー値となっているので、

HasFormulaで、はじかれるので問題ないのですが、

エラー値そのものが値としてセル入っている場合は、

If Cells(i, 1) = "" Then

ここで、「型が一致しません」のエラーが発生してしまいます。

これを避けるには、

If Not IsError(Cells(i, 1)) Then
  If Not Cells(i, 1).HasFormula Then
    If Cells(i, 1) = "" Then

      '空白
    End If
  End If
End If


IsErrorはエラー値かどうか判定し、エラー値の場合は、Trueが返ります。

IsErrorとHasFormulaは、どちらが先でも良いですし、Andで判定しても問題ありません。

ここまで判定すれば問題ないでしょう。

しかし、たかが空白判定に、これほど面倒な事をする必要があるのでしょうか・・・

VBA関数はいろいろ用意されています。

If IsEmpty(Cells(i, 1)) Then
  '空白
End If


これだけで、いままで列挙してきた問題点を全て解決して、空白判定が出来ます。

マクロVBAを上達する為には、VBA関数の習得は必須です。

どんなVBA関数があるかは、一通り見て置く事をお勧め致します。


上記の赤訂正の部分について、ご指摘を受けました。

計算結果が空白("")を値貼り付けした場合に、IsEmptyはFalseを返します。

Excelの機能のジャンプでも、「空白セル」として判定されません。

従って、その前の3段階判定がやはり必要になります。

やはり、空白判定は、とても面倒なものです。




同じテーマ「ExcelマクロVBA技術解説」の記事

実行時にトラップ可能なエラー番号一覧
論理積(And)論理和(Or)と真(True)偽(False)の判定
VBAにおける括弧()の使い方
Rangeオブジェクト.Valueの省略について
ユーザー操作を制限する(Locked,Protect,ScrollArea)
プログラミングの基本〜ロジックの組み立て
シートに数式を設定する時のセル参照の指定方法

新着記事 ・・・新着記事一覧を見る

最後の空白(や指定文字)以降の文字を取り出す|エクセル関数超技(3月26日)
先頭の数値、最後の数値を取り出す|エクセル関数超技(3月26日)
Excelファイルを開かずにシート名をチェック|ExcelマクロVBAサンプル集(3月23日)
数式の参照しているセルを取得する|ExcelマクロVBAサンプル集(3月18日)
CSVの読み込み方法(改の改)|ExcelマクロVBAサンプル集(3月17日)
変数とプロシージャーの命名について|ExcelマクロVBA技術解説(2月12日)
ファイルの一覧取得・削除(File)|Google Apps Script入門(1月24日)
フォルダの一覧取得・作成・削除(Folder)|Google Apps Script入門(1月24日)
フォルダとファイルを扱う(DriveApp)|Google Apps Script入門(1月24日)
スプレッドシートが非常に遅い、高速化するには|Google Apps Script入門(1月17日)

アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|ExcelマクロVBA入門
2.RangeとCellsの使い方|ExcelマクロVBA入門
3.徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)|エクセル関数超技
4.Range以外の指定方法(Cells,Rows,Columns)|ExcelマクロVBA入門
5.セルの参照範囲を可変にする(OFFSET,COUNTA,MATCH)|エクセル関数超技
6.セルのコピー&値の貼り付け(PasteSpecial)|ExcelマクロVBA入門
7.変数とデータ型(Dim)|ExcelマクロVBA入門
8.ひらがな⇔カタカナの変換|エクセル基本操作
9.CSVの読み込み方法|ExcelマクロVBAサンプル集
10.VBAのFindメソッドの使い方には注意が必要です|ExcelマクロVBA技術解説



  • >
  • >
  • >
  • 空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)

  • このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。

    ↑ PAGE TOP