Puanlamada renklendirme

kemalist

Altın Üye
Katılım
4 Haziran 2008
Mesajlar
795
Excel Vers. ve Dili
Excel 2021 TÜRKÇE
Altın Üyelik Bitiş Tarihi
24-01-2026
Puanlama esnasında isimlerde renklendirme yapmak istiyorum.Dosya ektedir.İlginiz için şimdiden teşekkür ederim.
 

Ekli dosyalar

Murat OSMA

Altın Üye
Altın Üye
Katılım
23 Mayıs 2011
Mesajlar
5,508
Excel Vers. ve Dili
Microsoft 365 TR-EN
Altın Üyelik Bitiş Tarihi
31-12-2028
Bunun için makro şart mı peki?
Koşullu Biçimlendirme ile de yapılabilir.
 

kemalist

Altın Üye
Katılım
4 Haziran 2008
Mesajlar
795
Excel Vers. ve Dili
Excel 2021 TÜRKÇE
Altın Üyelik Bitiş Tarihi
24-01-2026
satır sayısı çok fazla olduğu için makro istedim.
 

YUSUF44

Destek Ekibi
Destek Ekibi
Katılım
4 Ocak 2006
Mesajlar
12,071
Excel Vers. ve Dili
İş : Ofis 365 - Türkçe
Ev: Ofis 365 - Türkçe
Aşağıdaki makroyu deneyiniz:

PHP:
Sub renklendir()
sonL = Cells(Rows.Count, "L").End(3).Row
sonR = Cells(Rows.Count, "R").End(3).Row
Application.ScreenUpdating = False
    For i = 2 To sonL
        If WorksheetFunction.CountIf(Range("R1:R" & sonR), Cells(i, "L")) > 0 Then
            If WorksheetFunction.VLookup(Cells(i, "L"), Range("R1:S" & sonR), 2, 0) < Cells(i, "M") Then
                Cells(i, "L").Interior.ThemeColor = xlThemeColorAccent6
            ElseIf WorksheetFunction.VLookup(Cells(i, "L"), Range("R1:S" & sonR), 2, 0) > Cells(i, "M") Then
                Cells(i, "L").Interior.Color = vbRed
                Cells(i, "L").Font.Color = vbWhite
            Else
                Cells(i, "L").Interior.Color = vbYellow
            End If
        Else
            Cells(i, "L").Interior.Color = xlNone
        End If
    Next
Application.ScreenUpdating = True
End Sub
 

kemalist

Altın Üye
Katılım
4 Haziran 2008
Mesajlar
795
Excel Vers. ve Dili
Excel 2021 TÜRKÇE
Altın Üyelik Bitiş Tarihi
24-01-2026
Çok teşekkür ederim Yusuf Bey
 

Korhan Ayhan

Administrator
Yönetici
Admin
Katılım
15 Mart 2005
Mesajlar
42,763
Excel Vers. ve Dili
Microsoft 365 Tr-En 64 Bit
Alternatif;

Hız olarak avantaj sağlayabilir.

C++:
Option Explicit

Sub Renklendir()
    Dim Dizi As Object, Son As Long, Veri As Variant, X As Long, Zaman As Double
    
    Zaman = Timer
    
    Set Dizi = CreateObject("Scripting.Dictionary")
    
    Range("L2:L" & Rows.Count).Interior.Color = xlNone
    Range("L2:L" & Rows.Count).Font.Color = 0
    
    Son = Cells(Rows.Count, "R").End(3).Row
    Veri = Range("R2:S" & Son).Value
    
    For X = LBound(Veri) To UBound(Veri)
        Dizi.Item(Veri(X, 1)) = Veri(X, 2)
    Next
    
    Son = Cells(Rows.Count, "L").End(3).Row
    Veri = Range("L2:M" & Son).Value
    
    For X = LBound(Veri) To UBound(Veri)
        If Dizi.Exists(Veri(X, 1)) Then
            If Veri(X, 2) > Dizi.Item(Veri(X, 1)) Then
                Cells(X + 1, "L").Interior.Color = 9359529
            ElseIf Veri(X, 2) < Dizi.Item(Veri(X, 1)) Then
                Cells(X + 1, "L").Interior.Color = 255
                Cells(X + 1, "L").Font.Color = 16777215
            ElseIf Veri(X, 2) = Dizi.Item(Veri(X, 1)) Then
                Cells(X + 1, "L").Interior.Color = 65535
            End If
        End If
    Next
    
    MsgBox "İşleminiz tamamlanmıştır." & Chr(10) & Chr(10) & _
           "İşlem süresi ; " & Format(Timer - Zaman, "0.00") & " Saniye", vbInformation
End Sub
 

kemalist

Altın Üye
Katılım
4 Haziran 2008
Mesajlar
795
Excel Vers. ve Dili
Excel 2021 TÜRKÇE
Altın Üyelik Bitiş Tarihi
24-01-2026
Korhan Hocam çok teşekkürler
 

Muhammet Okumuş

Destek Ekibi
Destek Ekibi
Katılım
28 Eylül 2007
Mesajlar
4,025
Excel Vers. ve Dili
2013 Türkçe
Korhan Bey, dizideki değerlere renk uygulanabilyor mu? (Hücreye yazdırmadan)
 

Korhan Ayhan

Administrator
Yönetici
Admin
Katılım
15 Mart 2005
Mesajlar
42,763
Excel Vers. ve Dili
Microsoft 365 Tr-En 64 Bit
Hücre aralığını diziye alırken değerlerini alıyoruz. Bu değerleri döngü içinde hızlı bir şekilde sorguluyoruz. Dizide renklendirme yapabilmemiz için değere hücre özelliği kazandırmak gerekir. Bu da dizinin mantığına terstir. Klasik For-Each-Next ya da For-Next döngüsü ile hücreler işleme alınarak renk özelliği kullanılabilir. Ama bu durumda veri yoğunluğuna göre biraz yavaşlık söz konusu olacaktır. Ben işin içine dizi yöntemini katarak biraz da olsa hızlandırmaya çalıştım.
 
Üst