![Excel VBA Instrを使用して配列内の要素を検索する](https://vba-nav.com/wp-content/uploads/2023/11/53454ec9eef6cd09ba3e403b8812ca03.png)
Excel VBAの Instrを使用して配列内の要素を検索します。具体的な使い方や、注意点やサンプルコードを紹介します。
Excel VBA Instrで配列内要素を検索する利用
以下のようなシーンで利用されます。
・配列内の特定の要素を検索し、その位置を知りたい場合に使用します。例えば、配列内の特定の値のインデックスを見つけたり、配列内の文字列パターンを検索する場合などに利用します。
position = InStr([start], string1, string2, [compare])
・「start」: 検索を開始する位置を指定します。省略可能で、デフォルトは1です。
・「string1」: 検索される文字列を指定します。
・「string2」: 検索する文字列を指定します。
・「compare」: 比較方法を指定します。省略可能です。
ポイント
startが省略された場合、検索は文字列の先頭から開始します。
Excel VBA Instrで配列内要素を検索するサンプルコード
Option Explicit
Sub ExampleUsage()
Dim position As Integer
Dim myArray(3) As String
Dim search_string As String
Dim i As Integer
' 配列の初期化
myArray(0) = "apple"
myArray(1) = "banana"
myArray(2) = "orange"
myArray(3) = "banana"
' 検索する文字列を設定
search_string = "banana"
' 配列内での検索を実行
For i = LBound(myArray) To UBound(myArray)
position = InStr(1, myArray(i), search_string)
If position > 0 Then
MsgBox "文字列 '" & search_string & "' は配列の " & i & " 番目に見つかりました。"
Exit For ' 最初に見つかったインデックスのみを表示し、ループを終了します
End If
Next i
If position = 0 Then
MsgBox "文字列 '" & search_string & "' は配列内で見つかりませんでした。"
End If
End Sub
サンプルコードは、配列内の要素を検索して文字列 banana を見つけます。見つかった場合、そのインデックスをメッセージボックスで表示します。
Excel VBA Instrで文字列内で特定文字列や文字が最初に出現する位置を返す
あなたもExcel VBAのスキルを証明できるようにしませんか? Excel VBA エキスパート資格は、VBAプログラミングの専門家としての信頼性を高め、キャリアの成長に大きく貢献し、求人市場での競争力を高め、キャリア機会を拡大します。 当サイトでは、Excel VBAエキスパート認定資格取得に役立つ情報を提供しています。まずは問題集から挑戦してみませんか? ExcelVBAエキスパートベーシック
仕事の効率をあげるためにExcelVBAを利用する人が対象の問題集です。
ExcelVBAエキスパートスタンダード
ExcelVBAの開発を仕事にする人が対象の問題集です。