InStrRev関数:文字列の末尾から指定の文字列を検索し文字位置を返す

InStrRev 関数は Excel VBA で用意されている関数の一つで、対象の文字列の中に指定した文字列が現れる最初の位置を検索し、見つかった位置を文字位置で返します。 InStrRev 関数では文字列の末尾から先頭に向かって検索していきます。ここでは Excel VBA における InStrRev 関数の使い方について解説します。

(Last modified: )

InStrRev関数の定義と使い方

InStrRev 関数は対象の文字列の中に指定の文字列が最初に現れる位置を文字位置で返します。

InStrRev(stringcheck,stringmatch)

1 番目の引数に対象となる文字列を指定します。 2 番目の引数に検索する文字列を指定します。 InStrRev 関数の場合は文字列の末尾から先頭に向かって検索を行い、見つかった位置を文字位置で返します。見つからなかった場合は 0 が返されます。

InStr 関数とは引数の順番が変わっているので注意してください。

次の例を見てください。

Debug.Print InStrRev("FLOWER","OW")       '3
Debug.Print InStrRev("京都府京都市","都")  '5

1 番目に指定した文字列の先頭から 2 番目に指定した文字列から最初に現れる位置を末尾から先頭に向かって検索し、位置をイミディエイトウィンドウに表示します。半角文字か全角文字かに関係なく結果は文字位置で返される点に注意してください。

検索開始位置を指定する

検索する開始位置を指定する場合は、省略可能な 3 番目の引数に開始位置を文字数で指定してください。

次の例を見てください。

Debug.Print InStrRev("京都府京都市","都", 4)  '2

対象の文字列の 4 文字目から先頭に向かって検索を行うので、 5 番目の位置にある "都" ではなく 2 番目の一にある "都" が一致するため 2 を返します。

文字列を比較するときの種類を指定する

文字列が一致しているかどうか比較するときの比較方法の種類を指定する場合は、省略可能な 4 番目の引数に値を指定します。指定可能な値は次の通りです。

定数説明
vbUseCompareOption-1Option Compareステートメントの設定を使用して比較を実行します
vbBinaryCompare0バイナリ比較を実行します
vbTextCompare1テキスト比較を実行します
vbDatabaseCompare2Microsoft Access のみ。 データベース内の情報に基づいて比較を実行します

デフォルトの値は vbBinaryCompare です。なお vbUseCompareOption を指定するとエラーが表示されました。

なお 4 番目の引数を指定する場合は、省略可能な 3 番目の引数も併せて指定する必要があります。

サンプルコード

それでは簡単なサンプルを作成して試してみます。

Option Explicit

Sub InStrRev関数()
    Range("D3").Value = InStrRev(Range("B3").Value, Range("C3").Value)
    Range("D4").Value = InStrRev(Range("B4").Value, Range("C4").Value)
End Sub

InStrRev関数の定義と使い方(1)

このプログラムを実行すると InStrRev 関数を使って B3 セルから B4 セルに入力されている文字列の末尾から先頭に向かって C3 セルから C4 セルに入力されている文字列を検索し、見つかった文字位置を取得します。取得した位置を D3 セルから D6 セルにそれぞれ代入します。

InStrRev関数の定義と使い方(2)

文字列の中で見つかる位置をすべて取得する

InStrRev 関数を使うと末尾または指定した位置から先頭に向かって指定の文字が見つかった最初の位置を取得することができますが、最初の位置以外にも一致する部分がある場合に、すべての一致する位置を取得する方法です。

例えば下記のサンプルを実行すると、最初に見つかる 8 が表示されます。

Option Explicit

Sub InStrRev関数()
    Debug.Print InStrRev("京都府京都市下京区", "京")
End Sub

ただこの文字列の中には他にも "京" があります。これらの位置をすべて取得するには例えば次のようにプログラムを変更します。

Option Explicit

Sub InStrRev関数()
    Dim position As Integer
    position = 0

    Do
        position = InStrRev("京都府京都市下京区", "京", position - 1)
        If position <> 0 Then
            Debug.Print position
        End If
    Loop Until position = 0 Or position = 1
End Sub

文字列の中で見つかる位置をすべて取得する(1)

InStrRev 関数を使って指定の文字列が見つかったら、今度は前回見つかった位置から 1 を引いた 位置から検索をもう一度行います。これを見つからなくなるまで繰り返します。プログラムを実行するとイミディエイトウィンドウには 8, 4, 1 と順番に指定の文字列が見つかった文字位置を表示します。(一番先頭の文字が見つかった場合にエラーにならないように 0 または 1 以外になったときに繰り返し処理を継続します)。

文字列の中で見つかる位置をすべて取得する(1)

-- --

Excel VBA における InStrRev 関数の使い方について解説しました。

( Written by Tatsuo Ikura )

Profile
profile_img

著者 / TATSUO IKURA

プログラミングや開発環境構築の解説サイトを運営しています。