エクセルで別シートのリストからデータを紐付けするには、
どのようにすればよろしいでしょうか?
関数でもVBAでも良いので教えてください。
リストのA列、B列に文字列が記入してあります。
Sheet1のB列の文字列を検索値として、
リストのA列の文字列と部分一致するものの横の列(B列)の値を
Sheet1のC列に紐付けしたいのですが、どのようにすればよろしいでしょうか?
※リストの「1AA111」という文字列とSheet1の「1AA111-G」という文字列の場合
「1AA111」の箇所で紐付けしたい(図を参照下さい)
エクセルは2007,2010を使用しております。
よろしくお願い致します。
No.2ベストアンサー
- 回答日時:
こんばんは!
VBAでの一例です。
↓の画像のように左側Sheetが「Sheet1」というSheet名で元データがあるとします。
右側Sheet名は 「リスト」としています。
Alt+F11キー → メニュー → 挿入 → 標準モジュール → VBE画面に
↓のコードをコピー&ペーストしてマクロを実行してみてください。
(Alt+F8キー → マクロ → マクロ実行です)
Sub test() 'この行から
Dim i As Long, k As Long
Dim wS1 As Worksheet, wS2 As Worksheet
Set wS1 = Worksheets("Sheet1")
Set wS2 = Worksheets("リスト")
Application.ScreenUpdating = False
wS1.Columns(3).ClearContents
For i = 3 To wS1.Cells(Rows.Count, 1).End(xlUp).Row '←Sheet1の3行目~A列最終行まで
For k = 1 To wS2.Cells(Rows.Count, 1).End(xlUp).Row '←「リスト」Sheetの1行目~A列最終行まで
If InStr(wS1.Cells(i, 2), wS2.Cells(k, 1)) > 0 Then
wS1.Cells(i, 3) = wS2.Cells(k, 2)
End If
Next k
Next i
Application.ScreenUpdating = True
End Sub 'この行まで
※ 関数でないので、データ変更があるたびにマクロを実行する必要があります。m(_ _)m
No.1
- 回答日時:
末尾に付加する文字列に関する情報がもう少しあれば、何もできないということはありません。
しかしあまりスマートな方法になるとも思えないので、素直に、末尾に付加する文字列の部分を別の列に分けることをお勧めします。そうすれば、付加される前の文字列を VLOOKUP などで検索することにより、リストの 2 列目(リストの B 列)を持ってくることができますね?
文字列どうしをつなげるのは簡単です。「=b3&c3」といった数式でできます。
なおそういう処理をなさろうとする理由(データの種類、作業の目的など)が分かれば、もっと良い方法を提示できることもあるかもしれません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) エクセルの条件付き書式で*を使いたい 4 2022/05/13 16:49
- Excel(エクセル) Excel 値を返す数式についてです 3 2022/11/21 20:08
- Excel(エクセル) 【Excel】指定した文字列に該当する行を重複しないようにリスト 3 2022/03/30 12:27
- Excel(エクセル) Excelのリストにある文字を含むセルを、複数の色で色付けしたいです 2 2022/08/11 17:39
- Excel(エクセル) エクセルデーターの並び替え 5 2022/08/06 09:59
- Excel(エクセル) Vlookup関数で#N/Aエラー表示について 3 2022/09/03 20:59
- Excel(エクセル) エクセルの数式で教えてください。 1 2023/06/15 14:11
- Excel(エクセル) SUMIFSと日付変換 10 2023/04/16 15:38
- Visual Basic(VBA) 【至急】 当方初心者です。 マクロについて知恵をお貸しください。 ★したい動作 ①リストE列2行目か 4 2022/09/29 18:56
- Access(アクセス) CSVファイルの「0落ち」にVBA 6 2023/02/02 15:27
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
エクセルで一致するデータを紐付けしたい。
財務・会計・経理
-
エクセルのエラーメッセージ「400」って?
Visual Basic(VBA)
-
別のシートから値を取得するとき
Visual Basic(VBA)
-
-
4
エクセル VBA で他の表のリストを紐付けたい
その他(Microsoft Office)
-
5
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
6
Excel VBAで同じフォルダ内のファイルを開くには?
Excel(エクセル)
-
7
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
8
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
9
VBAを何回も作り直して、容量が増えた
Excel(エクセル)
-
10
EXCEL VBAで、セルの文字列の前後に文字を入力する方法は?
その他(Microsoft Office)
-
11
Cellsのかっこの中はどっちが行と列なの?
Visual Basic(VBA)
-
12
エクセルVBAでセルに入力したパスでブックを開く
Excel(エクセル)
-
13
UserForm1.Showでエラーになります。
工学
-
14
Excelで2つのデータの突合せをしたいです
Excel(エクセル)
-
15
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
16
エクセルで文字列の任意の場所に文字を挿入するマクロを教えてください
Excel(エクセル)
-
17
Excelにて、シート間で、データーを比較して、一致したら別シートへ転記するコードを教えてください。
Microsoft ASP
-
18
【VBA】指定したセルと同じ値で、別シートにあるセルに移動するには?
Visual Basic(VBA)
-
19
エクセル countif関数で、範囲を可変にするには
Excel(エクセル)
-
20
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VLOOKUPの列番号の最大は?
-
エクセルで離れた列を選択して...
-
「段」と「行」の違いがよくわ...
-
LEFT関数とIF関数の組み合わせ...
-
エクセルのソートで、数字より...
-
Alt+Shift+↑を一括で行うには、...
-
VBA 指定した列にある日時デー...
-
Excelの行数、列数を増やしたい...
-
エクセルで住所を県と市・郡と...
-
VBA
-
「コピー → 行列を入れ替えて貼...
-
エクセルマクロPrivate Subを複...
-
エクセルで複数列の検索をマク...
-
エクセルマクロで表の途中の集...
-
(VBA)Excelの特定の範囲にデー...
-
エクセルで最初の行や列を開け...
-
エクセル マクロ 範囲指定で...
-
エクセルマクロの組み方
-
EXCELVBAでリストボックス複数...
-
横軸を日付・時間とするグラフ化
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで離れた列を選択して...
-
VLOOKUPの列番号の最大は?
-
「段」と「行」の違いがよくわ...
-
LEFT関数とIF関数の組み合わせ...
-
VBA 指定した列にある日時デー...
-
CSVファイルの「0落ち」にVBA
-
エクセルで住所を県と市・郡と...
-
Excelの行数、列数を増やしたい...
-
エクセルで複数列の検索をマク...
-
エクセルマクロの組み方
-
Alt+Shift+↑を一括で行うには、...
-
えABのある列って
-
エクセルのソートで、数字より...
-
エクセル マクロ 範囲指定で...
-
VBAで結合セルを転記する法を教...
-
VBAで別ブックの列を検索し、該...
-
エクセルマクロPrivate Subを複...
-
列方向、行方向の定義
-
リストからデータを紐付けしたい
-
Accessのレポートで繰り返し表...
おすすめ情報