お世話になります。
条件付き書式で設定できることは承知ですが、マクロを使って条件と一致するセルの背景を
塗りつぶすプログラムについて質問です。
例えば、シートのB列、C列に取得したデータを入力して、D列、E列にB列の最大値、最小値を
関数を使って計算してあります。
B列はD列の最大値を参照して最大値を塗りつぶし、C列はE列の最小値を参照して最小値を塗りつぶす
下記のマクロを組みましたが、下記の様に条件が一致する数値が同じ行にあるとC列の塗りつぶしが
実行されません。
どこの記述が間違っているのでしょうか。ご教授お願い致します。
<データ>
B列 C列 D列 E列
1 5 30 B列の最大値 C列の最小値
2 10 35
3 15 50
4 20 45
5 25 15
<プログラム>
sub test()
Dim i As Integer
i = 2
Do While i < 7
'A列の最大値を塗りつぶす
If Cells(i, 2).Value = Cells(2, 4) Then
Cells(i, 2).Interior.ColorIndex = 16
'B列の最小値を塗りつぶす
ElseIf Cells(i, 3).Value = Cells(2, 5) Then
Cells(i, 3).Interior.ColorIndex = 16
End If
i = i + 1
Loop
end sub
No.3ベストアンサー
- 回答日時:
No1.No2の方の指示に従い、修正してみました。
(コメントも誤っていたので修正しました。)Cells(2,4)の参照はCells(2,4).Valueとしました。(Cells(2,5)も同様)
-------------------------------
Sub test()
Dim i As Integer
i = 2
Do While i < 7
'B列の最大値を塗りつぶす(A列->B列)
If Cells(i, 2).Value = Cells(2, 4).Value Then
Cells(i, 2).Interior.ColorIndex = 16
End If
'C列の最小値を塗りつぶす(B列->C列)
If Cells(i, 3).Value = Cells(2, 5).Value Then
Cells(i, 3).Interior.ColorIndex = 16
End If
i = i + 1
Loop
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) まとめシートから集計シートへA列のコードが一致したら1行コピーするマクロをネット上で見つけました。こ 1 2022/08/30 14:11
- Visual Basic(VBA) 列と行の名前(重複あり)が交差するセルに、データを入力したい 2 2022/06/25 22:42
- Visual Basic(VBA) マクロ実行時、自動で背景色を変えたい。 C列にあるチェックボックスをチェックするとB列に「TRUE」 4 2022/11/08 11:14
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Visual Basic(VBA) VBAで最新のデータを別シートに転記する方法をお教えください。 3 2022/04/07 19:20
- Visual Basic(VBA) 追記する列を増やしたい 2つのデータを検索・照合して元データにないデータを下記マクロで商品名を追記し 9 2022/10/05 10:50
- Visual Basic(VBA) ExcelVBAのマクロについて。 9 2022/05/04 14:50
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Visual Basic(VBA) VBAで教えて頂きたいのですが? 1 2022/04/29 02:36
- Visual Basic(VBA) 3つの条件を指定してVBAで行を削除したい 条件1:分類1が重複 条件2:分類2が重複 条件3:個数 6 2022/06/24 11:07
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Worksheets メソッドは失敗しま...
-
B列の最終行までA列をオート...
-
vba 2つの条件が一致したら...
-
Changeイベントでの複数セルの...
-
エクセル 2つの表の並べ替え
-
エクセルでフォームのチェック...
-
VBAを使って検索したセルをコピ...
-
【VBA】2つのシートの値を比較...
-
文字列の結合を空白行まで実行
-
VBAコンボボックスで選択した値...
-
マクロ 最終列をコピーして最終...
-
VBA 値と一致した行の一部の列...
-
URLのリンク切れをマクロを使っ...
-
Excelで、あるセルの値に応じて...
-
VBAでのリスト不一致抽出について
-
マクロについて。S列の途中から...
-
エクセルVBA intersect colu...
-
VBマクロ 色の付いたセルを...
-
VBAを用いて条件付きの平均値、...
-
データグリッドビューの一番最...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Worksheets メソッドは失敗しま...
-
Cellsのかっこの中はどっちが行...
-
VBAのコードを教えてください
-
VBAを使って検索したセルをコピ...
-
B列の最終行までA列をオート...
-
エクセルvbaについて
-
vba 2つの条件が一致したら...
-
Excelで、あるセルの値に応じて...
-
VBA UserFormからの転記で
-
VBAのFind関数で結合セルを検索...
-
文字列の結合を空白行まで実行
-
IIF関数の使い方
-
VBA 何かしら文字が入っていたら
-
マクロ 最終列をコピーして最終...
-
Changeイベントでの複数セルの...
-
エクセルVBAにて =A1=B1とすれ...
-
【VBA】2つのシートの値を比較...
-
データグリッドビューの一番最...
-
VBマクロ 色の付いたセルを...
-
VBAで指定範囲内の空白セルを左...
おすすめ情報