
・Excel(M365)で、添付ファイルのようなVLOOKUP処理を作りたい(VBAで)のですが、作り方についてお教えいただけませんでしょうか
・具体的に実施したいこととしては、①Sheet1のE列と、Sheet2のC列をマッチングし、Sheet1のJ列の値を、Sheet2のM列へ転記する。その際、Sheet1にデータ重複している場合(例:CCC,DDD)、そのデータの最下行の値を転記する(例:CCC→400、DDD→700)②この重複データについては、アラームのため、該当するSheet2のB~C列を赤くセル反転させる。
・上記マッチングしない場合は、Sheet2へは特に転記はしない(例:EEE)
・何卒、よろしくお願いします。

No.1ベストアンサー
- 回答日時:
>VLOOKUP処理を作りたい(VBAで)
ソートなどをしても単純にVLOOKUPで出来る処理ではないと思いますよ
画像が細かくてよく分からないけれど
Sub test()
Dim Dic As Object
Dim ky As Variant
Dim i As Long
Set Dic = CreateObject("Scripting.Dictionary")
'データを取得
With Worksheets("Sheet1")
For i = 2 To .Cells(Rows.Count, "E").End(xlUp).Row
ky = .Cells(i, "E").Value
If Not Dic.Exists(ky) Then
Dic.Add ky, .Cells(i, "J").Value
Else
Dic.Item(ky) = .Cells(i, "J").Value & "|"
End If
Next
End With
'条件に合わせて出力
With Worksheets("Sheet2")
For i = 2 To .Cells(Rows.Count, "C").End(xlUp).Row
ky = .Cells(i, "C").Value
If Dic.Exists(ky) Then
.Cells(i, "M").Value = Split(Dic.Item(ky), "|")(0)
If UBound(Split(Dic.Item(ky), "|")) = 1 Then
.Cells(i, "B").Resize(, 2).Interior.ColorIndex = 3
End If
End If
Next
End With
Set Dic = Nothing
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Cellsのかっこの中はどっちが行...
-
Worksheets メソッドは失敗しま...
-
vba 2つの条件が一致したら...
-
マクロ 最終列をコピーして最終...
-
B列の最終行までA列をオート...
-
VBAのFind関数で結合セルを検索...
-
VBA 何かしら文字が入っていたら
-
DataGridViewに空白がある場合...
-
Excelで、あるセルの値に応じて...
-
VBA: 2列のリストボックスの2列...
-
VBAで、離れた複数の列に対して...
-
VBScriptでfindを使うには??
-
VBA 列が空白なら別のマクロへ...
-
期限を超えた日付に警告のメッ...
-
VB2005EE:DataGridViewでチェ...
-
データグリッドビューの一番最...
-
IIF関数の使い方
-
文字列の結合を空白行まで実行
-
VBマクロ 色の付いたセルを...
-
VBAでのリスト不一致抽出について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelで、あるセルの値に応じて...
-
Worksheets メソッドは失敗しま...
-
Cellsのかっこの中はどっちが行...
-
vba 2つの条件が一致したら...
-
【VBA】2つのシートの値を比較...
-
B列の最終行までA列をオート...
-
IIF関数の使い方
-
URLのリンク切れをマクロを使っ...
-
VBAを使って検索したセルをコピ...
-
DataGridViewに空白がある場合...
-
VBA 何かしら文字が入っていたら
-
VBAのFind関数で結合セルを検索...
-
複数の列の値を結合して別の列...
-
VBAでのリスト不一致抽出について
-
データグリッドビューの一番最...
-
VBAで指定範囲内の空白セルを左...
-
rowsとcolsの意味
-
【Excel VBA】 B列に特定の文字...
-
VBAで、特定の文字より後を削除...
-
エクセル 2つの表の並べ替え
おすすめ情報