excel2010を使用しています。
住所に含まれる番地の最初の数字だけを残し、ハイフン以外の数字をアスタリスクに変換。
さらに、番地の後に記載されているビル名を削除するという置き換えを一括で行いたいです。
何か方法はありませんでしょうか。
番地の数字やハイフンは全角の場合と半角の場合があり、
できればこれらも半角に統一したいです。
【置換前】
東京都台東区0-0-0 AAAビル
東京都豊島区1-1-1
神奈川県横浜市2-1-5 BBBビル
【置換後】
東京都台東区0-*-*
東京都豊島区1-*-*
神奈川県横浜市2-*-*
No.5
- 回答日時:
No.4です!
たびたびごめんなさい。
前回のコードで最後から3行目
>Cells(i, 2) = Left(Cells(i, 2), cnt + 1)
の行を
>Cells(i, 2) = Left(Cells(i, 2), cnt)
に訂正してください。
前回のコードですと、1文字余計なものが含まれてしまいます。
何度も失礼しました。m(_ _)m
No.4ベストアンサー
- 回答日時:
こんばんは!
VBAになってしまいますが、一例です。
データはA列の1行目からあるとします。
B列に表示するようにしてみました。
画面左下の操作したいSheet見出し上で右クリック → コードの表示 → VBE画面に
↓のコードをコピー&ペーストしてマクロを実行してみてください。
(Alt+F8キー → マクロ → マクロ実行です)
Sub Sample1() 'この行から
Dim i As Long, k As Long, cnt As Long, str As String
For i = 1 To Cells(Rows.Count, 1).End(xlUp).Row
Cells(i, 2) = StrConv(Cells(i, 1), vbNarrow)
cnt = 0
For k = 1 To Len(Cells(i, 2))
str = Mid(Cells(i, 2), k, 1)
If str = "-" Then
cnt = cnt + 1
ElseIf str Like "[0-9]" And cnt > 0 Then
Cells(i, 2) = WorksheetFunction.Replace(Cells(i, 2), k, 1, "*")
End If
Next k
For k = Len(Cells(i, 2)) To 1 Step -1
str = Mid(Cells(i, 2), k, 1)
If str = "*" Then
cnt = k
Exit For
End If
Next k
Cells(i, 2) = Left(Cells(i, 2), cnt + 1)
Next i
End Sub 'この行まで
こんな感じではどうでしょうか?m(_ _)m
No.3
- 回答日時:
おかしいですね・・・
私の環境では正常に動作しています。
よろしければ"-*-*-*"になったところの関数をコピペしていただけないでしょうか?
この回答への補足
再度試してみたところ、1-1-1の場合はうまくいきました。
ですが、番地の値を変更すると下記のような結果になってしまいます。
B1に入力
=LEFT(A1,FIND({"1","2","3","4","5","6","7","8","9","0"},
JIS(A1)&"1234567890")) & "-*-*"
A1 東京都台東区2-2-2 AAAビル
結果⇒東京都台東区2-2-2 AAAビル-*-*
B3に入力
=LEFT(A3,FIND({"1","2","3","4","5","6","7","8","9","0"},
JIS(A3)&"1234567890")) & "-*-*"
A3 東京都台東区3-3-1 AAAビル
結果⇒東京都台東区3-3-1-*-*
もしかしたら私の記述ミスか、環境の問題なのかもしれません。
とりあえず他の方の回答で解決してしまったため、
質問を打ち切らせていただきます。
ありがとうございました。
No.1
- 回答日時:
セルA1に住所が入力されているとして・・・
Excel2007以上の場合
隣のセルに =IF(A1="","",IFERROR(LEFT(A1,FIND("区",A1)+2)&"*-*",LEFT(A1,FIND("市",A1)+2)&"*-*"))
の式を入れて下へコピー
Excel2003以下の場合
=IF(A1="","",IF(ISERROR(LEFT(A1,FIND("区",A1)+2)&"*-*"),LEFT(A1,FIND("市",A1)+2)&"*-*",LEFT(A1,FIND("区",A1)+2)&"*-*"))
の式を入れて下へコピー
取り敢えず"市"と"区"の場合だけを想定してます。
変換できました。素晴らしいです。
説明不足で申し訳ないのですが、
実際のデータは番地の前に町名が入ることが多いので、区や市で終わることはほとんどありません。
その場合の変換は難しいでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) 【Excel】住所に郵便番号を付記する方法 3 2022/05/07 17:15
- 政治 東京特別区(23区)って何の意味があるのですか? 特別区を全て市にしてはいけないのですか? 例えば. 1 2022/11/12 22:05
- 政治 東京特別区(23区)って何の意味があるのですか? 特別区を全て市にしてはいけないのですか? 例えば. 1 2022/11/13 21:46
- 政治 東京特別区(23区)って何の意味があるのですか? 特別区を全て市にしてはいけないのですか? 例えば. 0 2022/11/13 17:24
- 転職 長く続けられる好条件の求人でしょうか? 3 2023/07/12 18:45
- 関東 ※東北の人からのにわか質問で不快に来たりムカついたらすいません、悪気はありません。 東京方面に住む人 8 2022/08/03 18:17
- その他(Microsoft Office) EXCELの1行を1枚の用紙にそれぞれ印刷したい。 3 2022/10/10 11:35
- その他(交通機関・地図) なんで関西の交通網って天国状態なの? 1 2022/04/16 06:57
- 政治 参議院の一票の格差を解消し、なおかつ問題の多い隣の県との合区を解消する方法を考えました 2 2022/11/15 11:40
- PHP ファイルの書き込みについて教えて下さい。 1 2023/03/20 12:01
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
EXCELで特定のセルに表示...
-
エクセル 数字をすべて○などの...
-
Excel内での検索結果をシート...
-
セルの値が変ると自動でマクロ...
-
Excelで、図形内の文字をセルに...
-
セルがクリックされた回数をカ...
-
フォントの色を指定して削除出...
-
エクセルでページ数をあるセル...
-
アポストロフィーの一括挿入 ...
-
クリックすると文章が表示され...
-
excelのソルバーをVBAで複数行...
-
太字に設定されているセルの個...
-
Excel2007 色のカウント (VBA)
-
マクロを実行すると画像がズレ...
-
[EXCEL] フォント変更が正常に...
-
空白セルを空セルに置き換える...
-
エクセルでPDFリンクを大量...
-
Excelで挿入した図をセルの中央...
-
エクセルでセルをダブルクリッ...
-
エクセルで小文字を大文字に・・・
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
EXCELで特定のセルに表示...
-
エクセル 数字をすべて○などの...
-
Excel内での検索結果をシート...
-
クリックすると文章が表示され...
-
Excelでセルをクリックす...
-
太字に設定されているセルの個...
-
Excel ハイパーリンクのURLを別...
-
Excelで、図形内の文字をセルに...
-
マクロを実行すると画像がズレ...
-
現在のセルの位置を返す関数は...
-
Excelで挿入した図をセルの中央...
-
フォントの色を指定して削除出...
-
VBA 見つからなかった時の処理
-
エクセルでの検索ボックスの作...
-
エクセル 未入力セルがあると...
-
Excel2007 色のカウント (VBA)
-
エクセルでPDFリンクを大量...
-
【EXCEL】先週の月曜日の日付を...
-
EXCELのセルや文字色の反映
-
セルがクリックされた回数をカ...
おすすめ情報