Çözüldü If döngü hatası

Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
Merhaba. Fotoğrafta görürdüğü gibi if döngüsü kullanmaya çalıştım ama beceremedim. Benim istediğim hücre rengi değiştir butonuna bastığımda emin misin diye sorsun. Eğer msgboxa evet dersem sütunları boyasın ve renkler güncellendi bilgisini versin istiyorum. Ama bu soruyu tek bir kere değil 6 kere filan soruyor bazen sonsuz döngüye giriyor. Hayır dersemde renkler güncellenmedi bilgisini versin ve boyama yapmasın. Yardımlarınızı bekliyorum.
Yazılı olan kodun resmi
 
Katılım
6 Mart 2005
Mesajlar
6,238
Excel Vers. ve Dili
Excel Vers. ve Dili:
Office 2016 TR 64 Bit
Altın Üyelik Bitiş Tarihi
22/12/2022
Deneyiniz.
Kod:
Private Sub CommandButton1_Click()
Dim hcr As Range
sor = MsgBox("Renkler güncellensin mi?", vbYesNo + vbQuestion)
For Each hcr In Range("D3:D20")
If sor = 6 Then
hcr.Interior.Color = 13995347

Else
MsgBox "Renkler güncellenmedi"
Exit Sub
End If
Next
MsgBox "Renkler günceldi"
End Sub
 
Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
Deneyiniz.
Kod:
Private Sub CommandButton1_Click()
Dim hcr As Range
sor = MsgBox("Renkler güncellensin mi?", vbYesNo + vbQuestion)
For Each hcr In Range("D3:D20")
If sor = 6 Then
hcr.Interior.Color = 13995347

Else
MsgBox "Renkler güncellenmedi"
Exit Sub
End If
Next
MsgBox "Renkler günceldi"
End Sub
Buton çalıştı ama renk değişikliği olmadı yazılan satır aralıkları hep aynı renk yapıyor. Orada yazdığım kodlar ile örnek sarıyı kırmızı kırmızıyı mavi böyle değiştire değiştire gitmedi.
 
Katılım
6 Mart 2005
Mesajlar
6,238
Excel Vers. ve Dili
Excel Vers. ve Dili:
Office 2016 TR 64 Bit
Altın Üyelik Bitiş Tarihi
22/12/2022
Buton çalıştı ama renk değişikliği olmadı yazılan satır aralıkları hep aynı renk yapıyor. Orada yazdığım kodlar ile örnek sarıyı kırmızı kırmızıyı mavi böyle değiştire değiştire gitmedi.
O zaman önceki kodla çalışmalısınız her satırdaki sorguya göre işlem devam etmeli.Sorunuzun bundan kurtulma istediğiniz şeklinde anladım.
 
Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
Aslında bu evet hayırı eklemeden önce herşey güzel çalışıyordu. Ama ben bunuda eklemek istiyorum. Ama bir türlü beceremedim. Her renk değiştirmesinde evet hayır penceresi çıkıyor.
 
Katılım
5 Kasım 2006
Mesajlar
572
Excel Vers. ve Dili
TÜRKCE Excel 2021 32bit
For each ile mantıksız olmuş gibi.
Mesela hücreyi seçip butona basınca soru sorup işlem yapılabilir.Böylece seçilen renklenir.
 
Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
Buradaki mantık farklı renklerde hücreler var. Kırmızı, mavi, yeşil, turuncu vb. butona basınca benim belirlediğim sıra ile maviyi kırmızıya, kırmızıyı yeşile, yeşili turuncuya çeviriyor.Tek tek hücre seçme yok belirlediğim aralık içindeki bütün hücreler için geçerli oluyor. Bu böyle devam ediyor. Benim istediğim butona basınca tek bir defa emin misin diye sorsun ona göre işlem yapsın.
 

Orion1

Uzman
Uzman
Katılım
1 Mart 2005
Mesajlar
22,254
Excel Vers. ve Dili
Win7 Home Basic TR 64 Bit

Ofis-2010-TR 32 Bit
Buyurun.:cool:
Kod:
Private Sub CommandButton1_Click()
Dim hcr As Range
If MsgBox("Renkler güncellensin mi?", vbYesNo + vbQuestion) = vbYes Then
For Each hcr In Range("D3:D20")
hcr.Interior.Color = 13995347
Next
GoTo 10
Else
MsgBox "Renkler güncellenmedi"
Exit Sub
End If
10:
MsgBox "Renkler günceldi"
End Sub
 

Necdet

Moderatör
Yönetici
Katılım
4 Haziran 2005
Mesajlar
15,209
Excel Vers. ve Dili
Ofis 365 Türkçe
Örnek dosya eklemezseniz daha çok yazışırsınız.
 
Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
Buyurun.:cool:
Kod:
Private Sub CommandButton1_Click()
Dim hcr As Range
If MsgBox("Renkler güncellensin mi?", vbYesNo + vbQuestion) = vbYes Then
For Each hcr In Range("D3:D20")
hcr.Interior.Color = 13995347
Next
GoTo 10
Else
MsgBox "Renkler güncellenmedi"
Exit Sub
End If
10:
MsgBox "Renkler günceldi"
End Sub
Elinize sağlık sorunsuz çalıştı. İlginizden dolayı teşekkür ederim. Ben birde nöbet çetele konusu açmıştım. Size zahmet olmazsa onada bakabilir misiniz?
 
Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
Buyurun.:cool:
Kod:
Private Sub CommandButton1_Click()
Dim hcr As Range
If MsgBox("Renkler güncellensin mi?", vbYesNo + vbQuestion) = vbYes Then
For Each hcr In Range("D3:D20")
hcr.Interior.Color = 13995347
Next
GoTo 10
Else
MsgBox "Renkler güncellenmedi"
Exit Sub
End If
10:
MsgBox "Renkler günceldi"
End Sub
Kod fotoğrafı
Ufak bir hata daha gerçekleşti. Şuan hayır dersem sütunları boyamıyor ve güncellenmedi bilgisini veriyor. Bunda sıkıntı yok ama evet dediğimde 2 kere güncellendi 1 kere güncellenmedi uyarısı veriyor.
 

Orion1

Uzman
Uzman
Katılım
1 Mart 2005
Mesajlar
22,254
Excel Vers. ve Dili
Win7 Home Basic TR 64 Bit

Ofis-2010-TR 32 Bit
Kod fotoğrafı
Ufak bir hata daha gerçekleşti. Şuan hayır dersem sütunları boyamıyor ve güncellenmedi bilgisini veriyor. Bunda sıkıntı yok ama evet dediğimde 2 kere güncellendi 1 kere güncellenmedi uyarısı veriyor.
2 Kere mesaj vermesine imkan yok.
Bakın örnek dosya için link verdim.
İndirip deneyiniz.:cool:

DOSYAYI INDIR

...
 
Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
2 Kere mesaj vermesine imkan yok.
Bakın örnek dosya için link verdim.
İndirip deneyiniz.:cool:

DOSYAYI INDIR
...
Evet sizinki hata vermiyor ama benim kodlar farklı. Tek renk değişikliği yapmıyorum 5 renk değişikliği yaptığımdan dolayı ekleme yaptım.
 

Orion1

Uzman
Uzman
Katılım
1 Mart 2005
Mesajlar
22,254
Excel Vers. ve Dili
Win7 Home Basic TR 64 Bit

Ofis-2010-TR 32 Bit
Örnek dosyanızı ekleyin bakayım.:cool:
 
Son düzenleme:
Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
Evet haklısınız ama bende askeri birlikteyim bu bilgisayarlarda internet yok ve herhangi bir bellek, cd vb. şeyler takılmıyor. Ondan dolayı fotoğraf yükledim. Ama başka türlü yüklemeyi deniyim.
 

Orion1

Uzman
Uzman
Katılım
1 Mart 2005
Mesajlar
22,254
Excel Vers. ve Dili
Win7 Home Basic TR 64 Bit

Ofis-2010-TR 32 Bit
Yüklediğiniz fotoğrafta sadece bir hücreye bir renk ekleniyor.
Yazdığınız kodlardaki en alttaki kod rengi geçerli olur.:cool:
 

Orion1

Uzman
Uzman
Katılım
1 Mart 2005
Mesajlar
22,254
Excel Vers. ve Dili
Win7 Home Basic TR 64 Bit

Ofis-2010-TR 32 Bit
Şöyle deneyin.:cool:
Kod:
Sub DoluÇerçeve1_Tıklat()
Dim hcr As Range
If MsgBox("Renkler güncellensin mi?", vbYesNo + vbQuestion) = vbYes Then
For Each hcr In Range("D3:D20")
hcr.Interior.Color = 13995347
'kodlarınız
'kodlarınız
'kodlarınız
Next
GoTo 10
Else
MsgBox "Renkler güncellenmedi"
Exit Sub
End If
10:
MsgBox "Renkler günceldi"
End Sub
 
Katılım
19 Mayıs 2019
Mesajlar
61
Excel Vers. ve Dili
Excel 2010 türkçe
Altın Üyelik Bitiş Tarihi
20-05-2020
Şöyle deneyin.:cool:
Kod:
Sub DoluÇerçeve1_Tıklat()
Dim hcr As Range
If MsgBox("Renkler güncellensin mi?", vbYesNo + vbQuestion) = vbYes Then
For Each hcr In Range("D3:D20")
hcr.Interior.Color = 13995347
'kodlarınız
'kodlarınız
'kodlarınız
Next
GoTo 10
Else
MsgBox "Renkler güncellenmedi"
Exit Sub
End If
10:
MsgBox "Renkler günceldi"
End Sub
Sanırsam ihtiyacımız olan "Exit Sub" koduymuş.(y)Sayenizde hallettim sabrınız ve ilginizden dolayı teşekkür ederim.
 
Üst