質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

1回答

3210閲覧

Excelの住所録から建物名を抽出する方法

camellia080

総合スコア0

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2023/09/18 19:45

実現したいこと

スペースで区切られていない住所から建物名だけを抽出したい
例:
東京都○区○○1-1-1ABCビル111→ABCビル
東京都○区○○1-1-1カタカナハイツ111→カタカナハイツ
東京都○区○○1-1-1漢字荘111→漢字荘

前提

住所録をexcelで管理しています
データは1住所1セルごとにスペースやカンマ区切りなく入っています

表記は統一されておらず
”東京都○区○○1-1-1”
”東京都○区○○1丁目1-1"
”東京都○区○○一丁目1-1”
のパターンがあります

また建物名に関しても
建物名がはいっていないもの ”東京都○区○○1-1-1-111”
建物名と部屋番号① ”東京都○区○○1-1-1建物名111”  
建物名と部屋番号② ”東京都○区○○1-1-1建物名111号室”
など同一の建物でも複数の表記があります

建物名は漢字,カタカナ,アルファベット表記があります

試したこと

建物名を抽出する方法が分からなかったため、
まず関数で丁目以降の部分を抽出できないか試しました。

=MID(A1, MATCH(TRUE, ISNUMBER(1*MID(A1, ROW($1:$1000), 1)), 0)+1, LEN(A1))

見よう見まねでVBAでも試しました。

VBA

1Sub ExtractData () 2 Dim rng As Range 3 Dim cell As Range 4 Dim address As String 5 Dim buildingName As String 6 Dim i As Integer 7 8 Set rng = ThisWorkbook.Sheets("report (1)").Range("$BC1:BC" & ThisWorkbook.Sheets("report (1)").Cells(Rows.Count, 1).End(xlUp).Row) 9 10 For Each cell In rng 11 address = cell.Value 12 i = InStrRev(address, "丁目") 13 14 15 buildingName = Mid(address, i + 2) 16 17 cell.Offset(0, 1).Value = buildingName 18 Next cell 19End Sub

ただどちらにしても表記ブレがあるせいで"1-1-1"と"1-1"の2パターン生じてしまいます。

次に”-”以降を抽出する方法

VBA

1Sub ExtractData() 2 Dim rng As Range 3 Dim cell As Range 4 Set rng = ThisWorkbook.Sheets("report (1)").Range("BC:BC") 5 6 For Each cell In rng 7 If cell.Value <> "" Then 8 cell.Offset(0, 1).Value = Mid(cell.Value, InStrRev(cell.Value, "-") + 1) 9 End If 10 Next cell 11End Sub

こちらでは”-”のあと○号の部分の数字とそれ以降の建物名と部屋番号部分が抽出できました。
ただこちらも数字が一桁の場合と2桁の場合があり、抽出後のデータから建物名以降を抜き出す方法が分かりません。

最後にchatgptに頼んで出力してもらったのがこちら

VBA

1Sub ExtractData() 2 Dim rng As Range 3 Dim cell As Range 4 Set rng = ThisWorkbook.Sheets("Sheet1").Range("A:A") 5 6 For Each cell In rng 7 If cell.Value <> "" Then 8 Dim str As String 9 str = cell.Value 10 Dim firstNumber As Integer 11 Dim secondNumber As Integer 12 Dim i As Integer 13 firstNumber = 0 14 secondNumber = 0 15 For i = 1 To Len(str) 16 If IsNumeric(Mid(str, i, 1)) Then 17 If firstNumber = 0 Then 18 firstNumber = i 19 Else 20 secondNumber = i 21 Exit For 22 End If 23 End If 24 Next i 25 If firstNumber > 0 And secondNumber > 0 Then 26 cell.Offset(0, 1).Value = Mid(str, firstNumber + 1, secondNumber - firstNumber - 1) 27 Else 28 cell.Offset(0, 1).Value = "N/A" 29 End If 30 End If 31 Next cell 32End Sub

こちらだとそもそも抽出できませんでした(1丁目1のような表記になっているものは”丁目”が抽出されました)。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。
Microsoft office365

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hoshi-takanori

2023/09/18 20:10

> 建物名は漢字,カタカナ,アルファベット表記があります 第2○○ビルのように数字を含む場合もありそう…。 住所の正規化の記事は色々ありますが、建物名を抽出するならこれとか参考になるかも? https://qiita.com/YSRKEN/items/5371e67950425ace6a73
guest

回答1

0

提示された例をみると、以下の方法でとりだすことができそうです。
数字と数字の間に挟まれた数字以外で構成される文字列。
上記の文字列が取り出せれば、建物名となります。

vba

1Sub ExtractData() 2 Dim rng As Range 3 Dim cell As Range 4 Dim address As String 5 Dim buildingName As String 6 Dim i As Integer 7 8 Set rng = ThisWorkbook.Sheets("report (1)").Range("$BC1:BC" & ThisWorkbook.Sheets("report (1)").Cells(Rows.Count, 1).End(xlUp).Row) 9 10 For Each cell In rng 11 address = cell.Value 12 Call Tatemonomei(address, buildingName) 13 14 cell.Offset(0, 1).Value = buildingName 15 Next cell 16End Sub 17 18Public Sub Tatemonomei(ByVal addr As String, ByRef building) 19 Dim RE As Object 20 Dim rematch As Object 21 building = "" 22 Set RE = CreateObject("VBScript.RegExp") 23 RE.Pattern = "([0-90-9])([^0-90-9]+)([0-90-9])*(号|号室)?$" 24 RE.Global = True 25 Set rematch = RE.Execute(addr) 26 If rematch.Count < 1 Then Exit Sub 27 building = rematch(0).submatches(1) 28End Sub

全て、上記のパターン通りならこれで問題ないはずですが、例外がある場合は、その都度対応が必要かと思います。
このマクロでは
東京都○区○○1丁目漢字荘123 は "丁目漢字荘" を抽出します。
東京都○区○○1丁目1漢字荘123号室 は "号室" を抽出します。
提示されたケース以外に例外があるようでしたら、追記してください。
対応可能であれば、対応します。

投稿2023/09/19 03:31

編集2023/09/19 04:49
tatsu99

総合スコア5540

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問