
VBAで対象範囲の背景色が黒の部分のみ"-"をいれるという処理をしたいのですが、ループがうまく動いておらず最初のセルのみ"-"が入った状態です。
※対象範囲のセルは3列ずつ結合されています
コードは以下になります。VBA初心者のため、初歩的な質問かもしれませんがご回答よろしくお願いいたします。
Private Sub CommandButton1_Click()
Dim C As Range
Sheets("sheet1").Select
T33:BA74 の範囲を1セルずつ繰り返す
For Each C In Range("T33:BA74")
セルが黒のとき
If C.Interior.ColorIndex = 1 Then
C.Value = "-"
end If
'次のセルへ
Next
End Sub
No.4ベストアンサー
- 回答日時:
A1:F10の範囲で、
[A1+B1][C1+D1][E1+F1]
[A2+B2][C2+D2][E2+F2]
:
[A10+B10][C10+D10][E10+F10]
というようにセルを結合して、[E3+F3][A4+B4][C6+D6]を黒くして、
Dim C As Range
For Each C In Range("A1:F10")
If C.Interior.ColorIndex = 1 Then
C.Value = "-"
End If
Next
を試してみたところ、黒いセルのすべてに"-"が入りましたよ。
No.3
- 回答日時:
セルを結合して結合されている2番目3番目のセルを参照するような場合を想定しているのでしょうか
それならユーザー関数を使って左肩のセルを取り出してやればいいように思います
Function GetTopLeftCell( r as Range) as Range
if r.MergeCells = false then
' 結合していないので そのままrを返す
Set GetTopLeftCell = r
else
Set GetTopLeftCell = r.MergeArea.Reange("A1")
end if
End Function
No.1
- 回答日時:
これはExcelの仕様のようですよ
A1:C1に 『1』『1』『1』と入力して セルの結合をしてみてください
アラートが出ると思います
その文言の中に『左上のセルのデータのみ保持されます』とあります
つまり A1セル以外のデータは削除されてしまいます
このアラートで OKを押してから
A10セル選択 =A1、B10を選択 =B1、C10を選択 =C1 と入力
結果は 『1』『0』『0』になると思います
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) VBA 特定の列に入っているテキストをコピペ 2 2023/06/14 11:24
- Visual Basic(VBA) エクセルVBA ダブルクリックしたら色反転を指定したセルのみにしたい 2 2022/04/06 12:52
- Visual Basic(VBA) VBAの繰り返し処理について教えてください。 3 2022/08/02 13:21
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Visual Basic(VBA) エクセルで、1つのセルで上書き足し算して セルの範囲を指定できますか? パソコン初心者です。 お時間 3 2023/07/05 06:13
- Excel(エクセル) 日付で矢印マクロ 4 2023/07/25 16:47
- Excel(エクセル) エクセルで書式設定とフィルタの組み合わせでうまく行かないのですが 4 2022/10/07 10:02
- Visual Basic(VBA) VBAについて教えてください 4 2022/11/10 12:44
- Visual Basic(VBA) VBA初心者です。 VBAで行単位で条件付き書式の色をカウントしたいです。 大量のデータがあるExc 3 2022/06/08 10:00
- Visual Basic(VBA) VBA初心者です。 VBAで行単位で条件付き書式の色をカウントしたいです。 大量のデータがあるExc 3 2022/06/08 10:02
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルVBA 配列からセルに「...
-
【VBA】【ユーザーフォーム_Lis...
-
Excelで空白セル直前のセルデー...
-
エクセル VBA ボタンをクリック...
-
VBAマクロ実行時エラーの修正に...
-
QRコード作成マクロについて
-
VBA:日付を配列に入れ別セルに...
-
特定の色のついたセルを削除
-
Excel VBAでCheckboxの名前を変...
-
Excel VBA 同じ処理を複数回行...
-
HTMLのテーブルのセルの値をPHP...
-
エクセル マクロ データの転記
-
DataGridViewのフォーカス遷移...
-
複数指定セルの可視セルのみを...
-
エクセルVBA 郵便番号の書式判...
-
Excel 範囲指定スクショについ...
-
データグリッドビューの結合セ...
-
DataGridViewでグリッド内に線...
-
【Excel VBA】マクロで書き込ん...
-
VBA にて、条件付き書式で背景...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAマクロ実行時エラーの修正に...
-
Excel UserForm の表示位置
-
特定の色のついたセルを削除
-
Excelで空白セル直前のセルデー...
-
エクセルVBA 配列からセルに「...
-
【VBA】【ユーザーフォーム_Lis...
-
VBA:日付を配列に入れ別セルに...
-
複数指定セルの可視セルのみを...
-
C# DataGridViewで複数選択した...
-
【Excel VBA】マクロで書き込ん...
-
データグリッドビューの結合セ...
-
DataGridViewのフォーカス遷移...
-
Excel 範囲指定スクショについ...
-
EXCEL VBA 文中の書式ごと複写...
-
【Excel VBA】一番右端セルまで...
-
【VBA】写真の貼り付けコードが...
-
QRコード作成マクロについて
-
入力規則のリスト選択
-
CellEnterイベント仕様について
-
エクセル、マクロで番号を読込...
おすすめ情報