Excelで「表」を選択したい場合、ショートカットではCtrl+Shift+:(Windows)ですが、マクロでこれと同じ挙動をするプロパティとしてCurrentRegionが用意されています。
なお、「表」とは空白セル/先頭(末尾)列・行で分断された範囲のことを指します。
CurrentRegionプロパティの使い方
セルの所属する表を指定
対象.CurrentRegion
対象.CurrentRegion
data:image/s3,"s3://crabby-images/7d7f7/7d7f7d8e2ce1f8e3e872eeef90673f281cecfd0f" alt="currentregion1"
やりたいこととしては、こうした表に対して、
data:image/s3,"s3://crabby-images/fa058/fa0583cecb8cac71bf9720896644c1da6ec5590c" alt="currentregion2"
全体を選択し、
data:image/s3,"s3://crabby-images/3d096/3d0963c3fe8449be40595e390ed06e602f64d14c" alt="currentregion3"
E列に貼り付けをしてみます。
data:image/s3,"s3://crabby-images/64818/648186b99e6d69d2045cb48579a7556a330b80bb" alt="currentregion4"
A1~C7の表をこの場合選択したいわけですが、表内のいずれかのセル、たとえばRange(“A1”).CurrentRegion.Selectとしてやれば、
data:image/s3,"s3://crabby-images/ee72d/ee72d91df05e736195023c5acb5dc14bda11d096" alt="currentregion5"
A1セルの所属する表全体が選択されます。
Range(“C7”).CurrentRegionなど別のセルでもいいですし、表からはみ出なければ範囲指定でもOKです。表のサイズが変更になっても問題ないように、見出しのあるセルなどを指定するのが無難です。
Range(“C7”).CurrentRegionなど別のセルでもいいですし、表からはみ出なければ範囲指定でもOKです。表のサイズが変更になっても問題ないように、見出しのあるセルなどを指定するのが無難です。
data:image/s3,"s3://crabby-images/03103/031034641ca9146052f15aaa6696c23a13a0fcf6" alt="currentregion6"
あとは選択した表を貼り付けられればいいので、Range(“A1:A3”).CurrentRegion.Copy Range(“E1”)とでもしてやれば、
data:image/s3,"s3://crabby-images/5f392/5f392b8c18fb93b1fdf29741533cbb050a93baed" alt="currentregion7"
このように表をコピペすることができます。
コピーについてもう少しちゃんと知りたい方はこちらをご参照ください。
data:image/s3,"s3://crabby-images/44b36/44b36d0f8fac0be53447fdd93eac7bc139caa294" alt=""
関数・演算子・メソッド・プロパティ名から探すExcel/VBA(マクロ)使い方・組み合わせ方まとめ
こちらはExcelやメソッドの諸機能を、機能の名称から探せるまとめ記事です。
コメント