
・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で質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAでvlookup関数から、別シート参照するやり方・・・ 2 2022/11/14 18:49
- Excel(エクセル) LOOKUP関数を使えばいいのでしょうか。 2 2024/05/08 20:49
- Visual Basic(VBA) Sheet「状況」から、分類の年齢別カウント数をSheet「D表」へ転記する下記マクロを作っています 7 2022/12/14 17:57
- Excel(エクセル) SUMIFSと日付変換 10 2023/04/16 15:38
- Excel(エクセル) Excelにて、行の最後のセルの値をコピーして別sheetに張りつけるVBAコードをご教授願います 3 2022/11/20 14:35
- Visual Basic(VBA) VBA 別sheetからの転記なのですが 2 2023/05/22 15:55
- Visual Basic(VBA) VBAを教えていただきたいです。 添付のような「data sheet」があります。 他に、「集計 s 2 2023/11/07 12:51
- Excel(エクセル) 関数を教えていただきたいです。 添付のような「data sheet」があります。 他に、「集計 sh 3 2023/11/02 17:11
- Excel(エクセル) エクセルの日付抽出 2 2023/02/03 15:02
- Excel(エクセル) VBA Private Sub Worksheet_Changeで 1 2024/05/01 16:59
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【VBA】2つのシートの値を比較...
-
Worksheets メソッドは失敗しま...
-
VBAで指定範囲内の空白セルを左...
-
【VBA】オートフィルタで抽出し...
-
VBAを使って検索したセルをコピ...
-
URLのリンク切れをマクロを使っ...
-
VBAで、特定の文字より後を削除...
-
マクロ 最終列をコピーして最終...
-
VBAを用いて条件付きの平均値、...
-
vba 2つの条件が一致したら...
-
VBAのFind関数で結合セルを検索...
-
ExcelVBAで、必要な列を抽出す...
-
【VBA】複数行あるカンマ区切り...
-
cellsプロパティ列名をアルファ...
-
エクセル VBA 条件にあうセルの...
-
Worksheet_Change(ByVal Target...
-
B列の最終行までA列をオート...
-
Excel VBAにおける複数条件での...
-
R言語で読み込んだデータの列名...
-
C# 列の挿入
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelで、あるセルの値に応じて...
-
vba 2つの条件が一致したら...
-
Worksheets メソッドは失敗しま...
-
B列の最終行までA列をオート...
-
Cellsのかっこの中はどっちが行...
-
IIF関数の使い方
-
Changeイベントでの複数セルの...
-
【VBA】2つのシートの値を比較...
-
VBA 何かしら文字が入っていたら
-
URLのリンク切れをマクロを使っ...
-
VBAのFind関数で結合セルを検索...
-
DataGridViewに空白がある場合...
-
VBAを使って検索したセルをコピ...
-
文字列の結合を空白行まで実行
-
データグリッドビューの一番最...
-
VBAでのリスト不一致抽出について
-
エクセル 2つの表の並べ替え
-
rowsとcolsの意味
-
【Excel VBA】 B列に特定の文字...
-
VBA 列が空白なら別のマクロへ...
おすすめ情報