Aynı satırda aynı değerlere sahip diğer hücreleri silme

Katılım
4 Ağustos 2006
Mesajlar
135
Excel Vers. ve Dili
2017 Eng
Altın Üyelik Bitiş Tarihi
28/04/2018
merhaba
Aynı satırda yer alan aynı değere sahip diğer hücreleri nasıl silebiliriz.

Örn :
4,2,3,5,4,3,6,7,3,9 veriliyor.. 4 ve 3 ten birden fazla var

sonuç : 4,2,3,5, , ,6,7, ,9
4,2,3,5,6,7,9
 

Levent Menteşoğlu

Administrator
Yönetici
Admin
Katılım
13 Ekim 2004
Mesajlar
16,058
Excel Vers. ve Dili
Excel 2010-32 bit-Türkçe
Excel 365 -32 bit-Türkçe
Aşağıdaki kodu deneyin.

Kod:
Sub sil()
For a = Cells(5, 256).End(xlToLeft).Column To 3 Step -1
say = WorksheetFunction.CountIf(Rows(5), Cells(5, a))
If say > 1 Then Columns(a).Delete
Next
End Sub
 

Ali

Uzman
Katılım
21 Temmuz 2005
Mesajlar
7,915
Excel Vers. ve Dili
İş:Excel 2016-Türkçe
Alternatif
Bir modüle aşağıdaki kodları ekleyin.

Kod:
Function Benzersiz(Aralik As Range, i As Integer)
Application.Volatile
Dim ciftolmayan As New Collection
For Each ce In Aralik
On Error Resume Next
ciftolmayan.Add ce, CStr(ce)
Next ce
If i > ciftolmayan.Count Then
Benzersiz = ""
Else
Benzersiz = ciftolmayan(i)
End If
End Function
C12 hücrenizede

=Benzersiz($C$5:$L$5;SÜTUN()-2) yazıp sağa doğru çekin.
 
Katılım
4 Ağustos 2006
Mesajlar
135
Excel Vers. ve Dili
2017 Eng
Altın Üyelik Bitiş Tarihi
28/04/2018
Alternatif
Bir modüle aşağıdaki kodları ekleyin.

Kod:
Function Benzersiz(Aralik As Range, i As Integer)
Application.Volatile
Dim ciftolmayan As New Collection
For Each ce In Aralik
On Error Resume Next
ciftolmayan.Add ce, CStr(ce)
Next ce
If i > ciftolmayan.Count Then
Benzersiz = ""
Else
Benzersiz = ciftolmayan(i)
End If
End Function
C12 hücrenizede

=Benzersiz($C$5:$L$5;SÜTUN()-2) yazıp sağa doğru çekin.
sayın fructose
yazdıklarınızı yaptım. aNcak C12 ve diğer sürekliğim hücrelerde #VALUE! hatası verdi..
 
Katılım
4 Ağustos 2006
Mesajlar
135
Excel Vers. ve Dili
2017 Eng
Altın Üyelik Bitiş Tarihi
28/04/2018
Aşağıdaki kodu deneyin.

Kod:
Sub sil()
For a = Cells(5, 256).End(xlToLeft).Column To 3 Step -1
say = WorksheetFunction.CountIf(Rows(5), Cells(5, a))
If say > 1 Then Columns(a).Delete
Next
End Sub
sayın leventm
yazmış olduğunuz kod doğru sonuç veriyor. ancak alt alta yer alan birden fazla satır için (örneğin 5. ile 300. satır arasını verilerle dolduracağım) bu işlemi yaptırdığımda silinmemesi gereken veriler siliniyor (sütun silindiği için).Yazmış olduğunuz kodu belli geniş bir satır aralığı için ( 5 ile 500 arası)olacak şekilde düzenleyebilir misiniz..Ekteki dosyayı güncelledim...
 

Levent Menteşoğlu

Administrator
Yönetici
Admin
Katılım
13 Ekim 2004
Mesajlar
16,058
Excel Vers. ve Dili
Excel 2010-32 bit-Türkçe
Excel 365 -32 bit-Türkçe
Aşağıdaki kodu deneyin.

Kod:
Sub sil()
Application.ScreenUpdating = False
For b = 5 To [c65536].End(3).Row
For a = Cells(b, 256).End(xlToLeft).Column To 3 Step -1
say = WorksheetFunction.CountIf(Rows(b), Cells(b, a))
If say > 1 Then Cells(b, a).Delete Shift:=xlToLeft
Next
Next
End Sub
 

Ali

Uzman
Katılım
21 Temmuz 2005
Mesajlar
7,915
Excel Vers. ve Dili
İş:Excel 2016-Türkçe
Bende denedim hata vermiyor. Örneğiniz ekte.

Sarı alandaki veriler sizin istediğiniz verilerdir.
 
Katılım
4 Ağustos 2006
Mesajlar
135
Excel Vers. ve Dili
2017 Eng
Altın Üyelik Bitiş Tarihi
28/04/2018
Aşağıdaki kodu deneyin.

Kod:
Sub sil()
Application.ScreenUpdating = False
For b = 5 To [c65536].End(3).Row
For a = Cells(b, 256).End(xlToLeft).Column To 3 Step -1
say = WorksheetFunction.CountIf(Rows(b), Cells(b, a))
If say > 1 Then Cells(b, a).Delete Shift:=xlToLeft
Next
Next
End Sub
ellerine sağlık sayın leventm. çok teşekkür ederim
 
Katılım
4 Ağustos 2006
Mesajlar
135
Excel Vers. ve Dili
2017 Eng
Altın Üyelik Bitiş Tarihi
28/04/2018
Bende denedim hata vermiyor. Örneğiniz ekte.

Sarı alandaki veriler sizin istediğiniz verilerdir.
çok teşekkür ediyorum sayın fruktose.ellerinize sağlık
 
Üst