Excel VBA Resizeプロパティは、既存のセル範囲のサイズを変更するために使用します。指定した範囲の行数や列数を動的に変更できます。具体的な使い方や、注意点やサンプルコードを紹介します。
以下のようなシーンで利用されます。
・動的にセル範囲を変更する必要がある。
・データの追加や削除に応じて範囲を調整する。
・繰り返し処理で範囲を変更しながらセルにデータを入力する。
Range.Resize([RowSize], [ColumnSize])
・RowSize 新しい行数。省略可能で、指定しない場合は元の行数を使用します。
・ColumnSize 新しい列数。省略可能で、指定しない場合は元の列数を使用します。
・Resizeプロパティは、元の範囲のセルを基準にサイズを変更します。
・元の範囲の位置は変更されず、行数や列数だけが変更されます。
Option Explicit
Sub ResizeExample()
Dim rng As Range
Set rng = Range("A1:B2") ' 初期範囲はA1:B2
' 範囲を3行4列に変更
Set rng = rng.Resize(3, 4)
' 新しい範囲に値を設定
rng.Value = "Resized"
End Sub
動的に範囲を調整する例
この例では、開始セル"A1"を基準に5行3列の範囲が動的に設定され、その範囲に「Dynamic」という値が設定されます。
Option Explicit
Sub DynamicResizeExample()
Dim startCell As Range
Dim numberOfRows As Long
Dim numberOfColumns As Long
Set startCell = Range("A1") ' 開始セル
numberOfRows = 5 ' 動的に設定された行数
numberOfColumns = 3 ' 動的に設定された列数
' 開始セルを基準に範囲を調整
startCell.Resize(numberOfRows, numberOfColumns).Value = "Dynamic"
End Sub
これらの例を使って、Resizeプロパティの使い方で、さまざまなシーンでセル範囲を動的に変更できるようになります。
毎日のルーチン作業をExcel VBAで自動化し、時間を有効活用しませんか?Excel VBAエキスパート資格取得問題集を活用して資格取得、そして効率的な仕事を実現しましょう!
VBAエキスパート資格は、日常業務でExcelを多用し、手動作業を減らしたいと考えている方には価値あるものです。
ExcelVBAエキスパートベーシック
仕事の効率をあげるためにExcelVBAを利用する人が対象の問題集です。
ExcelVBAエキスパートスタンダード
ExcelVBAの開発を仕事にする人が対象の問題集です。
Excel VBA エキスパート資格について知りたい方は、下記「Excel VBAスキルアップを目指すなら知っておきたいVBAエキスパート」をご確認ください。
ExcelVBAの学習方法で効果的な学び方を知りたい方は、下記「Excel VBA初心者のための効果的な学習ガイド」をご確認ください。