掲題の件について教えてください。
Excel初心者です。
→→A列→→→→→→→→B列
1行 名古屋クリニック→→名古屋病院
2行 瑞穂歯科→→→→→→瑞穂専門学校
という表があった時、(各行ごとに)A列とB列に共通する『名古屋』、『瑞穂』を抽出する関数を教えていただきたくお願いいたします。
*値を指定する作業セルは使わない。(約4万行に異なる会社名が羅列してあり、その旧名称と新名称が対応しているかどうかをチェックする作業に使用するため)
説明不足な部分すらも分からないので、補足で質問していただければ幸いです。
よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
共通の文字列を抽出した結果が、「旧名称と新名称が対応しているかどうかをチェックする作業」に、果たしてどれほど役に立つのかは疑問が残るところですが、取り敢えずは、以下の様なVBAのマクロを使ってみられては如何でしょうか?
A列に入力されている文字列とB列に入力されている文字列との間で、共通している文字列が1つ以上あった場合、その中から最も長い文字列を抽出して、C列に表示させるというマクロです。
[註]マクロを実行される際には、念のために元のファイルをコピーしたファイルを使って抽出する事を御勧め致します。
Sub Macro()
Dim fr, lr, i, j, k, l, lm, p As Long
Dim s, sa, sb As String
fr = 1 '実際のデータが入力されている1番上の行の行番号
If Application.WorksheetFunction.CountIf(Range("A" & fr & ":A" & Columns.Rows.Count), "*?") = 0 Then Exit Sub
lr = Application.WorksheetFunction.Match(Chr(1), Columns("A:A"), -1)
For i = fr To lr
sa = Range("A" & i).Value
sb = Range("B" & i).Value
If sa = "" Or sb = "" Then GoTo Label1:
lm = Len(Range("A" & i).Value)
l = 0
p = 0
For j = 1 To lm
For k = 1 To lm - j + 1
s = Mid(sa, j, k)
If InStr(sb, s) > 0 And k > l Then
p = j
l = k
End If
Next k
Next j
If p * l > 0 Then Range("C" & i).Value = Mid(sa, p, l)
Label1:
Next i
End Sub
尚、もしも、1行目が項目名の入力欄などとして使用されていて、共通部分を抽出しなければならないデータが実際に入力されているのは、例えば2行目からであるなどという場合には、6行目の所にある
fr = 1
という記述を、
fr = 2
の様に変更して下さい。
それから、もしVBAの使い方が判らない場合には、以下のURLのページを参考にして下さい。
【参考URL】
よねさんのWordとExcelの小部屋 > ExcelVBA入門 > VBAコード(プログラム)の記述と実行の手順
http://www.eurus.dti.ne.jp/~yoneyama/Excel/vba/v …
早速のご回答ありがとうございます!
VBAから調べて実践してみます!笑
共通する最も長い文字列を抽出できるとのことなので、私が今回求めていた処理ができると思います!
ありがとうございました!!!
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語初心者 構造体 課題について 2 2023/03/10 19:48
- PHP 配列の値の更新方法について 1 2022/08/05 09:49
- Excel(エクセル) Excei で、項目の横展開 2 2023/07/15 09:56
- C言語・C++・C# C言語初心者 ポインタについて、お助けください、、 2 2023/03/15 23:50
- Excel(エクセル) 【VBA】元のシート内の文字列を別シートと比較し、一致したら元のシートの別のセルへ転記する方法。 3 2023/03/23 17:30
- Excel(エクセル) Excelの数式についての質問 1 2022/10/31 15:50
- Excel(エクセル) Power Query でのデータの一括修正について 2 2022/05/10 02:00
- Excel(エクセル) エクセルで沢山のレコードの最後に追記するには? 7 2023/04/10 13:27
- Excel(エクセル) エクセルで重複データから重複を削除して指定の列に抽出したい 11 2022/05/11 11:26
- Excel(エクセル) 【Excel】hyperlink関数を解除してもハイパーリンクが活きるようにできますか? 3 2023/05/22 11:22
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
すべてのシートを選択してエク...
-
エクセルで時刻を自動入力する方法
-
Excel VBA 答えが0になってし...
-
エクセルマクロについて データ...
-
ローマ字入力で「トゥ」を入力...
-
「未使用」と「不使用」ってど...
-
1点の辻の字に変換したいがエク...
-
Excelでエラー(#N/Aなど)値を...
-
エクセルで0.0と表示したい
-
コマンドプロンプトで表示が多...
-
PPTのスライド表示の画面の位置...
-
VLOOKUPで求めた数値をさらにVL...
-
ExcelでVBAを使用した際に、『...
-
バッチファイルでキー操作を行う。
-
コマンドプロンプトが実行中か...
-
VLOOKUP関数についての質問です...
-
もしセルが"#N/A"なら~をする...
-
高速フーリエ変換でデータ数が...
-
SUM関数の範囲に#N/Aが...
-
Eエクセルの計算方法で空欄を0...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
すべてのシートを選択してエク...
-
エクセルで時刻を自動入力する方法
-
Excel VBA 答えが0になってし...
-
Excelのデータが重いのはなぜで...
-
合計が0の行を削除
-
エクセル。ブック内検索で重複...
-
エクセルで、「袋詰め問題」を...
-
エクセルで漢字がうまく並び替...
-
EXCEL VBA 区切り位置のプログ...
-
エクセルで人名を50音順に表...
-
エクセルの計算式教えてください
-
エクセル 異なる列から部分的に...
-
エクセルにおいてタグからタグ...
-
Excel2007入力規則
-
「未使用」と「不使用」ってど...
-
ローマ字入力で「トゥ」を入力...
-
1点の辻の字に変換したいがエク...
-
Excelでエラー(#N/Aなど)値を...
-
ExcelでVBAを使用した際に、『...
-
もしセルが"#N/A"なら~をする...
おすすめ情報