Colorier une cellule suite a une condition
Résolu
r4944
Messages postés
122
Date d'inscription
Statut
Membre
Dernière intervention
-
cs_Le Pivert Messages postés 7904 Date d'inscription Statut Contributeur Dernière intervention -
cs_Le Pivert Messages postés 7904 Date d'inscription Statut Contributeur Dernière intervention -
A voir également:
- Colorier une cellule suite a une condition
- Excel cellule couleur si condition texte - Guide
- Aller à la ligne dans une cellule excel - Guide
- Bloquer une cellule excel - Guide
- Excel remplir automatiquement une cellule en fonction d'une autre ✓ - Forum Excel
- Excel : Remplir une cellule en fonction d'une autre ✓ - Forum Excel
4 réponses
Si tu veux aller à la dernière ligne de tes colonnes:
Dim q, q1, q2, q3 As Integer Dim Col As Range Dim c As Range Dim MaPlage As Range q = Range("A65536").End(xlUp).Row q1 = Range("H65536").End(xlUp).Row q2 = Range("J65536").End(xlUp).Row q3 = Range("R65536").End(xlUp).Row Set MaPlage = Range("A1:A" & q & ",H1:H" & q1 & ",J1:J" & q2 & ",R1:R" & q3 & "").Columns For q = 2 To ActiveSheet.Cells(ActiveSheet.Rows.Count, 1).End(xlUp).Row For Each Col In MaPlage For Each c In Col.Cells If Len(c.Value) = 0 Then c.Interior.Color = vbYellow 'If CStr(ActiveSheet.Cells(q, 31).Value) = "Completed - Appointment made / Complété - Nomination faite" _ ' And WorksheetFunction.CountIf(MaPlage, "") = 0 Then ' Select Case UCase(ActiveSheet.Cells(q, 14).Value) ' Case "INA_CIN" ' ActiveSheet.Cells(q, 42).Value = "XX" 'End Select ' End If Next c Next Col Next q
salut j'ai reussi a le faire tourner mais le probleme qu'il prend pas toujours en consideration la derniere ligne du tableau c'est bizarre un peu
voici mon code
voici mon code
Dim g As Integer Dim q As Integer Dim c As Range Dim d As Range Dim MaPlage As Range For q = 2 To ActiveSheet.Cells(ActiveSheet.Rows.Count, 1).End(xlUp).Row Set MaPlage = Range("A:H, J:R").Rows(q) For Each c In MaPlage.Cells If Len(c.Value) = 0 Then c.Interior.Color = vbYellow If CStr(ActiveSheet.Cells(q, 31).Value) = "Completed - Appointment made / Complété - Nomination faite" _ And WorksheetFunction.CountIf(MaPlage, "") = 0 Then Select Case UCase(ActiveSheet.Cells(q, 14).Value) Case "INA_CIN" ActiveSheet.Cells(q, 42).Value = "XX" End Select End If Next c Next q
EDIT : Ajout du LANGAGE dans les balises de code.
Explications disponibles ICI Merci d'y penser dans tes prochains messages. |
Dim g As Integer Dim q As Integer Dim Col As Range Dim c As Range Dim d As Range Dim MaPlage As Range For q = 2 To Range("R65536").End(xlUp).Row 'dernière ligne, a adapter à la colonne la plus remplie ici la R ' Set MaPlage = Range("A:H, J:R").Rows(q) For Each Col In Range("A1:A" & q & ",H1:H" & q & ",J1:J" & q & ",R1:r" & q & "").Columns ' a adapter For Each c In Col.Cells If Len(c.Value) = 0 Then c.Interior.Color = vbYellow 'If CStr(ActiveSheet.Cells(q, 31).Value) = "Completed - Appointment made / Complété - Nomination faite" _ ' And WorksheetFunction.CountIf(MaPlage, "") = 0 Then ' Select Case UCase(ActiveSheet.Cells(q, 14).Value) ' Case "INA_CIN" ' ActiveSheet.Cells(q, 42).Value = "XX" 'End Select ' End If Next Next Next
pour le savoir on met ceci:
Tu obtiens la dernière ligne de la colonne A. Tu fais donc une boucle sur toutes tes colonnes, de la ligne 2 à la ligne de la dernière ligne de la colonne A. Donc dans les colonnes qui sont plus remplies que la colonne A , le surplus n'est pas pris en compte.
Il faut donc que tu corriges le code en vert dans l'exemple que je t'ai donné. Moi ma boucle parcourt toutes les colonnes pour mettre la coloration. Tel qu'elle est je n'ai aucun bug.
Je ne sais pas où tu as eu ce code, mais il n'est pas bon!
@+ Le Pivert