VBAで自動化 VBA一覧 最終行・最終列 配列・データ操作

【VBA】最終行の一つ下:選択

Excel VBAで特定の操作を行う際に、シート内の最終行の一つ下のセルを選択することがよくあります。例えば、新しいデータを追加するために次の空白行を特定する場合などです。Excel VBAを使用して最終行の一つ下を選択する方法について説明します。

最終行を特定する方法

最終行を削除する前に、その最終行を正確に特定する必要があります。最終行を特定するには、以下のようにEndメソッドやCellsプロパティを使用します。

【VBA】UsedRangeプロパティ:最終行と最終列数

【VBA】Endメソッド:最終行と最終列数

【VBA】Findメソッド:基本構文と使用例

【VBA】最終行取得:Rangeオブジェクト

最終行の一つ下を選択する方法

最終行の一つ下を選択するためには、最終行を特定した後、その行の次の行(lastRow + 1)を選択します。

最終行の一つ下を選択する基本的な方法

以下のコードでは、最終行を特定し、その一つ下のセルを選択します。

【使用例: 最終行の一つ下を選択する】
Sub SelectCellBelowLastRow()

Dim ws As Worksheet
Dim lastRow As Long

' ワークシートを指定
Set ws = ThisWorkbook.Sheets("Sheet1")

' 列Aの最終行を取得
lastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row

' 最終行の一つ下のセルを選択
ws.Cells(lastRow + 1, "A").Select

MsgBox "列Aの最終行の一つ下を選択しました。"

End Sub

列Aを基準にして最終行を特定し、その一つ下の行のセル(列A)を選択します。

他の列やシートに応用する

最終行の一つ下を選択する方法は、他の列やシートにも応用できます。以下の例では、列Bで最終行の一つ下のセルを選択する方法です。

【使用例: 列Bで最終行の一つ下を選択する】
Sub SelectCellBelowLastRowInColumnB()

Dim ws As Worksheet
Dim lastRow As Long

' ワークシートを指定
Set ws = ThisWorkbook.Sheets("Sheet1")

' 列Bの最終行を取得
lastRow = ws.Cells(ws.Rows.Count, "B").End(xlUp).Row

' 最終行の一つ下のセルを選択
ws.Cells(lastRow + 1, "B").Select

MsgBox "列Bの最終行の一つ下を選択しました。"

End Sub

最終行の一つ下にデータを入力する

最終行の一つ下のセルにデータを入力することもできます。この例では、最終行の一つ下のセルに「新しいデータ」という文字列を入力します。

【使用例: 最終行の一つ下にデータを入力】
Sub AddDataBelowLastRow()

Dim ws As Worksheet
Dim lastRow As Long

' ワークシートを指定
Set ws = ThisWorkbook.Sheets("Sheet1")

' 列Aの最終行を取得
lastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row

' 最終行の一つ下のセルにデータを入力
ws.Cells(lastRow + 1, "A").Value = "新しいデータ"

MsgBox "最終行の一つ下にデータを追加しました。"

End Sub

最終行の一つ下を選択する際の注意点

  • 空白セルの扱い
    最終行を特定する際、途中に空白セルがある場合は、End(xlUp)メソッドを使用すると、正確に最終行を特定できます。空白セルが最終行の下にある場合、正しいセルが選択されるようにコードを適切に調整する必要があります。
  • 行が存在しない場合
    シートが空の場合やデータがまったくない場合には、最終行が存在しないため、エラーが発生する可能性があります。データの有無を確認する処理を追加することをお勧めします。

まとめ

Excel VBAで最終行の一つ下を選択する方法は、新しいデータを追加する際や、次の空白行に処理を適用する際に便利です。この記事で紹介した方法を使用して、最終行の一つ下のセルを正確に選択し、Excelでの作業を効率的に進めましょう。必要に応じて、特定の列やシートに応じてコードをカスタマイズすることも可能です。

-VBAで自動化, VBA一覧, 最終行・最終列, 配列・データ操作