VBA入門
第141回.行・列の表示・非表示(Hidden)

ExcelマクロVBAの基本と応用、エクセルVBAの初級・初心者向け解説
最終更新日:2020-04-03

第141回.行・列の表示・非表示(Hidden)


行または列を非表示にしたり、逆に表示したりする場合のマクロVBAについて説明します。
また、あるセルが表示されているか(可視セルか)の判定方法について解説します。


行や列はRangeオブジェクトです。
表示・非表示は、RangeオブジェクトのHiddenプロパティTrue/Falseを設定することで行います。

Rangeのプロパティ一覧 ・・・ 詳細解説ページへのリンクあり
エクセルの基本である、Rangeオブジェクトのプロパティの一覧です。太字リンク付きは、詳細解説ページ、または、応用したVBAコードがあるページにリンクしています。Excel2010までのRangeオブジェクトのプロパティ一覧 Excel2016で追加されたRangeオブジェクトのプロパティ一覧 CommentThreaded 範囲の左上隅のセルに関連付け…
Rangeのメソッド一覧 ・・・ 詳細解説ページへのリンクあり
エクセルの基本である、Rangeオブジェクトのメソッドの一覧です。太字リンク付きは、詳細解説ページ、または、応用したVBAコードがあるページにリンクしています。Excel2010までのRangeオブジェクトのメソッド一覧 Excel2013で追加されたRangeオブジェクトのメソッド一覧 FlashFill Trueは、

セルの非表示

セル単独では非表示にすることはできません。

Cells(3, 3).Hidden = True

これは、実行時にエラーとなります。

VBA マクロ セルの非表示

行または列に対してのみ、表示・表示を設定することができます。

行の表示・非表示

行の表示・非表示

Rows(行または行範囲).Hidden = True '非表示

Rows(行または行範囲).Hidden = False '表示


行の表示・非表示の使用例

3行目を非表示
Rows(3).Hidden = True

Cells(3, 3).EntireRow.Hidden = True

3行~5行を非表示
Rows("3:5").Hidden = True

Range("C3:E5").EntireRow.Hidden = True

上記のTrueをFalseに変更すれば表示になります。

列の表示・非表示

列の表示・非表示

Columns(列または列範囲).Hidden = True '非表示

Columns(列または列範囲).Hidden = False '表示

行・列の表示・非表示の使用例

C列を非表示
Columns(3).Hidden = True

Columns("C").Hidden = True

Cells(3, 3).EntireColumn.Hidden = True

C列~E列を非表示
Columns("C:E").Hidden = True

Range("C3:E5").EntireColumn.Hidden = True

上記のTrueをFalseに変更すれば表示になります。


セルが表示されているか(可視セルか)の判定方法

そのセルの行または列が非表示(不可視)かどうかで判定
If Cells(3, 3).EntireRow.Hidden Or _
  Cells(3, 3).EntireColumn.Hidden Then
  MsgBox "非表示"
Else
  MsgBox "表示"
End If

C3セルが可視セルか(表示されているか非表示か)を判定しています。

可視セル(SpecialCellsのxlCellTypeVisible)に含まれているかで判定
Sub sample()
  MsgBox isHidden(Range("C3"))
End Sub

Function isHidden(ByVal argRange As Range) As Boolean
  On Error Resume Next
  Dim myRange As Range
  Set myRange = argRange.SpecialCells(xlCellTypeVisible)
  If Err Then
    isHidden = True
    Exit Function
  End If
  If Intersect(argRange, myRange) Is Nothing Then
    isHidden = True
  Else
    isHidden = False
  End If
End Function

上記VBAの関数Functionは引数のセルが非表示の時Trueを返します。
VBA関数以外に、Excelワークシート関数をマクロVBAで使うことが出来ます、ワークシート関数は、VBA関数よりはるかに多くの関数があるので、ぜひ活用したいところです。。ワークシート関数を使う事で、VBAコードを非常に簡潔に記述することが出来る場合が多いものです。

滅多にないとは思いますが、全セルが非表示の場合には、SpecialCellsがエラーになります。
数式の入っているセル、定数の入っているセル、条件付き書式の設定されているセル、これらをシート全体やセル範囲の中から一括で取得する方法がVBAにはあります。手動でのジャンプ機能のセル選択をVBAで使うことができます。VBAでは、RangeオブジェクトのSpecialCellsメソッドがこの機能に該当します。

これに対処するために、On Error Resume Nextをいれて判定しています。
引数のセルが可視セルと重なっているかをIntersect関数 で判定しています。
IntersectメソッドはApplicationのメソッドで、複数のセル範囲の、重なっている部分のセル範囲を取得することが出来ます。あるセルが、特定セル範囲内にあるかどうかを判定したり、セル範囲の中から、特定の列や行の部分だけを取り出したりする場合に使います。



同じテーマ「マクロVBA入門」の記事

第99回.Replaceメソッド(置換)
第132回.その他のExcel機能(グループ化、重複の削除、オートフィル等)
第135回.ジャンプの選択オプション(SpecialCells)
第141回.行・列の表示・非表示(Hidden)
第105回.Callステートメント
第106回.Functionプロシージャー
第107回.プロシージャーの引数
第108回.変数の適用範囲(スコープ,Private,Public)
第100回.InputBoxメソッド(インプットボックス)
第101回.Midステートメント
第102回.Intersectメソッド


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

COUNTIF関数の結果は?(ツイッターお題)|エクセル雑感(5月30日)
エクセル&VBA オンライン講座|エクセル セミナー(5月29日)
アルファベットの26進(ツイッターお題)|エクセル雑感(5月19日)
VBAが消えてしまった!マクロが壊れて動かない!|エクセル雑感(5月8日)
時間に関する関数の扱い方(ツイッター投稿)|エクセル雑感(5月6日)
文字列のセルだけ結合(ツイッターのお題)|エクセル雑感(5月5日)
表示形式.言語設定|エクセル入門(5月1日)
GoogleスプレッドシートをExcelにインポートする|VBAサンプル集(4月28日)
ツイッターのお題「CSV編集」|エクセル雑感(4月25日)
プログレスバーを自作する|ユーザーフォーム入門(4月18日)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
6.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
7.繰り返し処理(For Next)|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.とにかく書いてみよう(Sub,End Sub)|VBA入門
10.マクロはどこに書くの(VBEの起動)|VBA入門




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


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



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