こんにちは、VBAエンジニアのやすこれです。
みなさんは、VBAでRight関数を使ったことがありますか?
- VBAで任意の文字列の内、右から指定した文字数分だけ取り出したい
- Right関数の使いどころがわからない
- Right関数の利用の仕方を実例付きで知りたい!
そこで今回は、任意の文字列の内、右から指定した文字数分だけを取り出せるRight関数の使い方と実務での応用方法をサンプルコード付きで紹介します。
VBAでのRight関数の使い方
Right関数の基本的な使い方
Right関数は、任意の文字列の右側から文字数を指定して一部を取り出す関数です。- 基本構文
Right(文字列, 長さ)
- 「長さ」が0の場合は、「””」(空白)を返す
- 「長さ」が指定した文字列の文字数以上の場合は、文字列全てを返す
- コード例
Right("ABCDE", 3)
文字列「ABCDE」の右から長さ「3」の文字列「CDE」を返します。RightB関数について
RightB関数は任意の文字列の右側からバイト数を指定して一部を取り出す関数です。引数の指定方法はRight関数と同じです。- 基本構文
RightB(文字列, 長さ)
- 「長さ」が0の場合は、「””」(空白)を返す
- 「長さ」が指定した文字列のバイト数以上の場合は、文字列全てを返す
- コード例
RightB("ABCDE", 6)
文字列「ABCDE」の左から長さ「6」バイトの文字列「CDE」を返します。- 2バイトで1文字
- 1文字に満たないバイト数「1」を「長さ」に指定した場合は、「””」(空白)を返す
Right関数の引数について
第二引数「長さ」を「0」にした場合
Right関数は、「長さ」が「0」の場合、「””」(空白)を返します。- コード例
Right("ABCDE", 0)
文字列「ABCDE」の右から、長さ「0」の文字列を取得するので、「””」(空白)を返します。第二引数「長さ」が文字数以上の場合
Right関数は、「文字列」の文字数より第二引数「長さ」が大きい場合、「文字列」全てを返します。- コード例
Right("ABCDE", 6)
「長さ」が文字列「ABCDE」の文字数「5」より大きいので、文字列全体の「”ABCDE”」を返します。Right関数の実務での利用方法
住所から市区町村以下を取得
'市区町村以下を取り出す元となる住所を定義
Dim trgtAddress As String
trgtAddress = "東京都〇〇区××"
'都道府県は「神奈川県」「和歌山県」「鹿児島県」のみ4文字でそれ以外は3文字
Dim endNum As Long
If InStr(trgtAddress, "県") = 4 Then
endNum = 4
Else
endNum = 3
End If
'市区町村以下を取得
Dim trgtCity As String
trgtCity = Right(trgtAddress, Len(trgtAddress) - endNum)
まず都道府県は「神奈川県」「和歌山県」「鹿児島県」以外はすべて3文字です。つまり、3つの県に該当している、4文字目が「県」(「InStr(〇〇, “県”) = 4」)の場合は左端から4文字を取得して、3つの県に該当しなければ、左端から3文字を取得すれば都道府県を取り出すことができます。
これを利用して、下記の部分で判定を行い、都道府県が対象の住所から何文字目までかを「endNum」に定義しています。
'都道府県は「神奈川県」「和歌山県」「鹿児島県」のみ4文字でそれ以外は3文字
Dim endNum As Long
If InStr(trgtAddress, "県") = 4 Then
endNum = 4
Else
endNum = 3
End If
あとは「Right関数」を使って、対象の住所「trgtAddress」の内、右から都道府県の次の文字位置までを取得すれば、住所から市区町村以下を取り出すことができます。この時、右からの文字数を取得するために文字列全体の文字数を取得する「Len関数」を使用しています。文字列全体の文字数から都道府県の終端「endNum」を引いたものが求めたい文字数となるので、次の処理で目的の文字列を取得できます。
'市区町村以下を取得
Dim trgtCity As String
trgtCity = Right(trgtAddress, Len(trgtAddress) - endNum)
- Len(文字列)
- 対象「文字列」の文字数を数値で返す
- ex)Len(“ABCDE”) → 5
- InStr(文字列1, 文字列2)
- 対象「文字列1」の内、「文字列2」が始まる位置を返す
- ex)InStr(“ABC”, “B”) → 2
キーワードより右側の文字列を取得
'キーワード右側を取り出す元となる文字列を定義
Dim trgtDepartment As String
trgtDepartment = "営業部営業第一課"
'キーワードを定義
Dim keyword As String
keyword = "部"
'キーワード位置を取得
Dim endNum As Long
endNum = InStr(trgtDepartment, keyword)
'キーワードから右側を取得
Dim trgtSection As String
trgtSection = Right(trgtDepartment, Len(trgtDepartment) - endNum)
まず、元となる文字列やキーワードを次の部分で定義します。'キーワード右側を取り出す元となる文字列を定義
Dim trgtDepartment As String
trgtDepartment = "営業部営業第一課"
'キーワードを定義
Dim keyword As String
keyword = "部"
つづいて、次の部分で、キーワード位置を取得します。'キーワード位置を取得
Dim endNum As Long
endNum = InStr(trgtDepartment, keyword)
- InStr(文字列1, 文字列2)
- 対象「文字列1」の内、「文字列2」が始まる位置を返す
- ex)InStr(“ABC”, “B”) → 2
この時、右からの文字数を取得するために文字列全体の文字数を取得する「Len関数」を使用しています。文字列全体の文字数からキーワードの終端「endNum」を引いたものが求めたい文字数となるので、次の処理で目的の文字列を取得できます。
'キーワードから右側を取得
Dim trgtSection As String
trgtSection = Right(trgtDepartment, Len(trgtDepartment) - endNum)
- Len(文字列)
- 対象「文字列」の文字数を数値で返す
- ex)Len(“ABCDE”) → 5
名字と名前を分ける
'フルネームを定義
Dim fullName As String
fullName = "田中 太郎"
'名字と名前を分ける位置を取得
Dim borderNum As Long
borderNum = InStr(fullName, " ")
'名字を取得
Dim lastName As String
lastName = Left(fullName, borderNum - 1)
'名前を取得
Dim fastName As String
fastName = Right(fullName, Len(fullName) - borderNum)
まず「InStr関数」を使って、名字と名前の間にある「スペース」の位置を取得して、「borderNum」に定義しています。'名字と名前を分ける位置を取得
Dim borderNum As Long
borderNum = InStr(fullName, " ")
- InStr(文字列1, 文字列2)
- 対象「文字列1」の内、「文字列2」が始まる位置を返す
- ex)InStr(“ABC”, “B”) → 2
'名字を取得
Dim lastName As String
lastName = Left(fullName, borderNum - 1)
- Left(文字列, 数値)
- 対象「文字列」を「数値」で指定した文字数だけ左から取り出す
- ex)Left(“ABCDE”, 3) → “ABC”
この時、右からの文字数を取得するために文字列全体の文字数を取得する「Len関数」を使用しています。文字列全体の文字数からスペースの位置「borderNum」を引いたものが求めたい文字数となるので、次の処理で目的の文字列を取得できます。
'名前を取得
Dim fastName As String
fastName = Right(fullName, Len(fullName) - borderNum)
- Len(文字列)
- 対象「文字列」の文字数を数値で返す
- ex)Len(“ABCDE”) → 5
フルパスをディレクトリとファイル名に分ける
'フルパスを定義
Dim trgtPath As String
trgtPath = "C:\サンプル\SampleFile.xlsx"
'ファイル名を取得
Dim fileName As String
fileName = Right(trgtPath, Len(trgtPath) - InStrRev(trgtPath, ""))
'ディレクトリを取得
Dim dirStr As String
dirStr = Replace(trgtPath, fileName, "")
まず次の部分で、ディレクトリとファイル名に分けたいフルパス「trgtPath」から、ファイル名「fileName」を取り出します。'フルパスを定義
Dim trgtPath As String
trgtPath = "C:\サンプル\SampleFile.xlsx"
'ファイル名を取得
Dim fileName As String
fileName = Right(trgtPath, Len(trgtPath) - InStrRev(trgtPath, ""))
画像のように「InStrRev(trgtPath, “\”)」の部分で末尾の「\」の位置、つまりディレクトリが終わる位置を取得しています。- InStrRev(文字列1, 文字列2)
- 対象「文字列1」の内、末尾から「文字列2」を検索し、その開始位置を返す
- ex)InStrRev(“ABCABC”, “B”) → 5
'ディレクトリを取得
Dim dirStr As String
dirStr = Replace(trgtPath, fileName, "")
画像のように「Replace関数」を使って、フルパス「trgtPath」からファイル名「fileName」を「空の文字列」に置き換えることでディレクトリ「dirStr」を取得しています。- Replace(文字列1, 文字列2, 文字列3)
- 対象「文字列1」から「文字列2」を検索し、「文字列3」に置き換える
- ex)Replace(“ABCDE”, “DE”, “”) → “ABC”
Replace関数については、下記でも詳しく解説しているので、読んでみてください。
また、ファイル名の取得は、Dir関数でも行うことができますので、あわせてご覧ください。
VBAでのRight関数まとめ
今回はVBAでのRight関数の使い方と実務での使用方法を紹介いたしました。VBARight関数の実務での利用方法
第二引数「長さ」に「0」を指定すると「””」(空白)を返すこと、文字数より大きいと文字列全体を返すことについても覚えておきましょう。まずは実例通り使ってみると、理解が深まり応用が効くのでおすすめです。- 住所から市区町村以下を取得
- キーワードより右側の文字列を取得
- 名字と名前を分ける
- フルパスをディレクトリとファイル名に分ける
ぜひ使ってみてください。