Baska bir listedeki verileri tekrarsız olarak yeni bir listeye alma

Katılım
17 Kasım 2007
Mesajlar
88
Excel Vers. ve Dili
Excel 2010 English
Altın Üyelik Bitiş Tarihi
24.02.2018
Merhabalar,

Herkese once tesekkurler,sizlerin sayenizde hergecen gun excel fonksiyon ve makro calısmalarında kendimizi gelistiriyoruz hemde islerimizi ciddi anlamda kolaylastırıyoruz. Uzerinde calıstıgım bir tablom var. Ordan bir kesiti sizinle paylasmak istiyorum. arsiv orneklerini de inceledim ama tam olarak istedigime ulasamadım.

Tabloya gore ''SK2012'' sayfasındaki sarı renkli B kolonunda bulunan acenta listesini (tekrarsız bir sekilde) ozet tablo olarak ''SKAGENCIES'' sayfasındaki sarı renkli F4 hucresinden asagıya dogru sıralamak istiyorum. Bununla ilgili bir ornegi uyarlamaya calıstım. CommandButton olusturup istege gore hucre secerek bu sıralamayı yaptırmak istedim ama sanırım bir sorun var.

Yardımlarınız icin tesekkur ederim.
 

Ekli dosyalar

Ömer BARAN

Uzman
Katılım
8 Mart 2011
Mesajlar
12,997
Excel Vers. ve Dili
Office 2013 ( 32 bit ) TÜRKÇE
Altın Üyelik Bitiş Tarihi
(18.03.2020) - Uzman olduğu için tarih geçersiz oldu.
SK2012 sayfasındaki listenin B sütunundaki firma isimlerinin olduğu alanı seçin, seçiliyken formül çubuğunun sol tarafındaki hücre adının görüntülendiği alana " liste " yazın, sonra aşağıdaki formülü diğer sayfa F4 hücresine yapıştırıp hücre içindeyken Ctrl+Alt+Enter tuşlarına birlikte basın (böylece dizi formülü oluşacak), son olarak o hücreyi aşağı doğru kopyalayınız.
 
Katılım
17 Kasım 2007
Mesajlar
88
Excel Vers. ve Dili
Excel 2010 English
Altın Üyelik Bitiş Tarihi
24.02.2018
SK2012 sayfasındaki listenin B sütunundaki firma isimlerinin olduğu alanı seçin, seçiliyken formül çubuğunun sol tarafındaki hücre adının görüntülendiği alana " liste " yazın, sonra aşağıdaki formülü diğer sayfa F4 hücresine yapıştırıp hücre içindeyken Ctrl+Alt+Enter tuşlarına birlikte basın (böylece dizi formülü oluşacak), son olarak o hücreyi aşağı doğru kopyalayınız.
Omer Bey tam olarak anlayamadım,asagıdaki formul derken bir formul goremiyorum.Ve sunu da belirteyim aslıda bu tablonu sadece cok kucuk bir kesiti ,daha bircok formulasyonlar var,epey agırlastı zaten ,bu nedenle formul kullanarak degil,mevcut basladıgım makro ile bu sorunumu cozmek istiyorum.
Bu konuda yardımcı olabilirmisiniz ?
 

Ömer BARAN

Uzman
Katılım
8 Mart 2011
Mesajlar
12,997
Excel Vers. ve Dili
Office 2013 ( 32 bit ) TÜRKÇE
Altın Üyelik Bitiş Tarihi
(18.03.2020) - Uzman olduğu için tarih geçersiz oldu.
Formülü eklemeyi unutmuşum, buyurun.
Kod:
=EĞER(EHATALIYSA(İNDİS(liste;KAÇINCI(0;EĞERSAY($F$3:F3;liste);0)))=DOĞRU;"";İNDİS(liste;KAÇINCI(0;EĞERSAY($F$3:F3;liste);0)))
 

ÖmerBey

Destek Ekibi
Destek Ekibi
Katılım
22 Ekim 2012
Mesajlar
4,340
Excel Vers. ve Dili
2007 Türkçe
Deneyiniz...
Kod:
Sub Benzersiz()
Dim s1, s2, x, a
Set s1 = Sheets("SK2012")
Set s2 = Sheets("SK AGENCIES")
x = 4
For a = 5 To s1.Range("B65500").End(3).Row
    If WorksheetFunction.CountIf(s1.Range("B5:B" & a), s1.Cells(a, "B")) = 1 Then
        s2.Cells(x, "F") = s1.Cells(a, "B")
        x = x + 1
    End If
Next
s2.Range("F" & x & ":F65500").ClearContents
End Sub
 
Katılım
17 Kasım 2007
Mesajlar
88
Excel Vers. ve Dili
Excel 2010 English
Altın Üyelik Bitiş Tarihi
24.02.2018
Destek ekibine çok teşekkür ediyorum.Mucit77'nin yardımı ile bu sorunum çözüldü.Ömer hocam size de teşekkürler fonksiyon için ama dedigim gibi makro ile yapmak istiyordum. Bir sorum daha var ama konu başlıkları karışmasın diye tekrar yeni konu açacagım...
Kolay gelsin.
 

TUNCA ERSİN

Altın Üye
Katılım
18 Ağustos 2021
Mesajlar
131
Excel Vers. ve Dili
Office Professional plus 2016 Tr
Altın Üyelik Bitiş Tarihi
18-08-2026
Sy. @ÖmerBey ;

Hocam peki buna koşul koyabilir miyiz.

Örneğin ;
H sütununda Backoffice koşuluna göre benzersiz olanlarını getirebilirmiyiz.

CA KARIBIK - ING. MICHAL RIECICKY

Backoffice

LEA CA

Backoffice

OREX TRAVEL S.R.O. KOSICE

B2B

OREX TRAVEL S.R.O.BRATISLAVA

B2B

OREX TRAVEL S.R.O.BRATISLAVA

Backoffice

CK ZLATKA S.R.O.

B2B

LG TRADE S.R.O.

Backoffice

DOVOLENKAREN KAROL KOLACNY

Backoffice

LG TRADE S.R.O.

B2B

CK ZLATKA S.R.O.

Backoffice

DOVOLENKAREN KAROL KOLACNY

B2B

TURSLOV S.R.O.

Backoffice

OREX TRAVEL S.R.O. BANSKA

Backoffice

JAN LUPTAK CA

B2B

LENKA

B2B

 

veyselemre

Özel Üye
Katılım
9 Mart 2005
Mesajlar
3,647
Excel Vers. ve Dili
Pro Plus 2021
Hocam peki buna koşul koyabilir miyiz.
Kod:
Sub test()

    Dim veri, i&
    With Sheets("SK2012")
        veri = .Range("B5:H" & .Cells(6001, "H").End(3).Row).Value
    End With

    With CreateObject("Scripting.Dictionary")
        For i = LBound(veri) To UBound(veri)
            If veri(i, 7) = "Backoffice" Then
                .Item(veri(i, 1)) = Null
            End If
        Next i
        veri = WorksheetFunction.Transpose(.keys)
    End With

    With Sheets("SK AGENCIES")
        .Range("F4:F" & .Rows.Count).ClearContents
        .Range("F4").Resize(UBound(veri)).Value = veri
    End With

End Sub
Kod:
Sub test()

    Dim rs As Object
    Set rs = CreateObject("ADODB.Recordset")
    With Sheets("SK AGENCIES")
        .Range("F4:F" & .Cells(Rows.Count, 6).End(xlUp).Row).ClearContents

        rs.Open "SELECT DISTINCT F1 FROM [SK2012$B5:H] WHERE F1 IS NOT NULL AND F7='Backoffice' ORDER BY F1", _
                "Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties='Excel 12.0 Xml;HDR=NO';" & _
                "Data Source=" & ActiveWorkbook.FullName

        .Range("F4").CopyFromRecordset rs
        rs.Close
    End With

End Sub
 

TUNCA ERSİN

Altın Üye
Katılım
18 Ağustos 2021
Mesajlar
131
Excel Vers. ve Dili
Office Professional plus 2016 Tr
Altın Üyelik Bitiş Tarihi
18-08-2026
Sy. @veyselemre ;

Hocam F1 hücresine koşulu yazdığımız zaman gelmesi için ne yapmamız gerekiyor.
Teşekkür ederim.
 

TUNCA ERSİN

Altın Üye
Katılım
18 Ağustos 2021
Mesajlar
131
Excel Vers. ve Dili
Office Professional plus 2016 Tr
Altın Üyelik Bitiş Tarihi
18-08-2026
Deneyiniz...
Kod:
Sub Benzersiz()
Dim s1, s2, x, a
Set s1 = Sheets("SK2012")
Set s2 = Sheets("SK AGENCIES")
x = 4
For a = 5 To s1.Range("B65500").End(3).Row
    If WorksheetFunction.CountIf(s1.Range("B5:B" & a), s1.Cells(a, "B")) = 1 Then
        s2.Cells(x, "F") = s1.Cells(a, "B")
        x = x + 1
    End If
Next
s2.Range("F" & x & ":F65500").ClearContents
End Sub


Ömer Hocam ;

Kod çok güzel çalışıyor . Ama Biraz Zaman alıyor. Hızlanması için bir şey yapmak gerekiyor. Veri Sayfası Yirmi Bin satır elli sütun Teşekkür ederim.
 
Üst