Skip to main content

AccessTr.neT


Excel Userform Da Listbox Nesnesi Alanlarının Biçimlendirmesi Hakkında.

Oğuz Türkyılmaz
Oğuz Türkyılmaz
73
1058

Excel Userform Da Listbox Nesnesi Alanlarının Biçimlendirmesi Hakkında.

Çözüldü #1
Merhaba herkese sağlıklı günler dilerim.

Excel çalışmasında düzenlediğim User Form da kayıtları listelediğim Listbox'ın Tutar alanında ki rakamları sağa dayalı yapmak ve ID alanını Büyükten küçüğe sıralamak istiyorum. Bunu nasıl yapabilirim. Yardımlarınız için teşekkür ederim.
Kod
Dim SonSatir As Variant

Private Sub btn_KayitEkle_Click()

If txt_MasrafTarihi <> "" And Com_Firma <> "" And txt_BelgeNo <> "" And Com_MasrafTuru <> "" And txt_Tutar <> "" Then

    SonSatir = WorksheetFunction.CountA(Worksheets("Ana Sayfa").Range("A:A")) + 1

    If SonSatir = 2 Then

                Worksheets("Ana Sayfa").Cells(SonSatir, 1) = 1
                Worksheets("Ana Sayfa").Cells(SonSatir, 2) = txt_MasrafTarihi.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 3) = Com_Firma.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 4) = txt_BelgeNo.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 5) = Com_MasrafTuru.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 6) = txt_Acıklama.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 7) = CDbl(txt_Tutar)
                
                Else
                
                Worksheets("Ana Sayfa").Cells(SonSatir, 1) = Worksheets("Ana Sayfa").Cells(SonSatir - 1, 1) + 1
                Worksheets("Ana Sayfa").Cells(SonSatir, 2) = txt_MasrafTarihi.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 3) = Com_Firma.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 4) = txt_BelgeNo.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 5) = Com_MasrafTuru.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 6) = txt_Acıklama.Value
                Worksheets("Ana Sayfa").Cells(SonSatir, 7) = CDbl(txt_Tutar)
    End If
                
Else

MsgBox "Giriş Alanlarının Tümünü Doldurunuz", , "Masraf Giriş Formu"

End If

Com_Firma.Value = ""
Com_MasrafTuru.Value = ""
txt_Acıklama.Value = ""
txt_BelgeNo.Value = ""
txt_MasrafTarihi.Value = ""
txt_Tutar.Value = ""


txt_MasrafTarihi = Format(Date, "dd.mm.yyyy")
Com_Firma.SetFocus




End Sub

Private Sub byn_Kapat_Click()

Unload UserForm1

End Sub

Private Sub txt_MasrafTarihi_Exit(ByVal Cancel As MSForms.ReturnBoolean)

txt_MasrafTarihi = Replace(txt_MasrafTarihi, ".", "")
txt_MasrafTarihi = Left(txt_MasrafTarihi, 2) & "." & Mid(txt_MasrafTarihi, 3, 2) & "." & Right(txt_MasrafTarihi, 4)

End Sub

Private Sub UserForm_Initialize()

ListBox1.ColumnCount = 7
ListBox1.RowSource = "MasrafListesi"
ListBox1.ColumnWidths = "30;70;70;70;240;170;70"

txt_MasrafTarihi = Format(Date, "dd.mm.yyyy")

End Sub

[Resim: do.php?img=10722]
.rar New Awa.rar (Dosya Boyutu: 281,73 KB | İndirme Sayısı: 9)
Access Çekirgesi 
[Resim: img-cray.gif]


Son Düzenleme: 16/02/2021, 11:26, Düzenleyen: Oğuz Türkyılmaz.
Cevapla
#2
Merhaba.
Rowsource kullandığınız için ya başka sayfada sıralatacaksınız verileri listoxa alacaksınız
yada verilerin alındığı sayfadan.

Rowsource olmadan ise Ado yada dizilerle olabilir.
Cevapla
#3
(17/02/2021 14:22)feraz Adlı Kullanıcıdan Alıntı: Meehaba.
Rowsource kullandığınız için ya başka sayfada sıralatacaksınız verileri listoxa alacaksınız
yada verilerin alındığı sayfadan.

Rowsource olmadan ise Ado yada dizilerle olabilir.

Verilerin alındığı Excel sayfasında sıralatamıyorum çünkü ID numarasını son boş satırın bir üstündeki dolu satırdaki verinin ID numarasını 1 arttırarak elde ediyorum. Orayı büyükten küçüğe dizersem o boş satıra bakacak ID numarası 1 çünkü en altta ve 2 yi vermeye kalkacak. Halbuki 2 1 in üstünde. Tıkandım o yüzden. Başka sayfaya atıp dizerek deniyim bakalım becerebilecekmiyim.
Access Çekirgesi 
[Resim: img-cray.gif]


Son Düzenleme: 17/02/2021, 18:12, Düzenleyen: Oğuz Türkyılmaz.
Cevapla
#4
Sıralatma kodunuz nedir bilemiyorum lakin normalde boş satırla alakası yok.Dosyayı deneyemedim bu arada tahminen yazdım.

Mesela alttaki gibi kod yazılabilir kodu kafadan yazfım büyük ihtimalle hata verebilir.Birde kodu unuttum descending gibi bişey eklenmesi gerek aklımda yok şuan.
Yada makro kaydet ilede uyarlayabilirsiniz sıralatıp son satırı.
Son = cells(rows.count,1).end(3).row
  range("a2:c" & son).sort range("a2"),header:=no

Bu arada kodu inceledim mobilden sonSatir i son dolunun bir altı olarak buluyorsunuz.Sıralarkende sonSatir -1 yazarsanız boş satırla işiniz olmaz.
Son Düzenleme: 17/02/2021, 23:37, Düzenleyen: feraz.
Cevapla
#5
Verileri alırken dizi kullanıp 2. diziye tersten aktarabilirsiniz. 2. dizideki verileri de listeye aktarırsanız sorun kalmaz bence. Internetten liste kutusuna veri aktarımıyla ilgili bilgi bulabilirsiniz.
Cevapla
#6
(18/02/2021 00:11)berduş Adlı Kullanıcıdan Alıntı: Verileri alırken dizi kullanıp 2. diziye tersten aktarabilirsiniz. 2. dizideki verileri de listeye aktarırsanız sorun kalmaz bence. Internetten liste kutusuna veri aktarımıyla ilgili bilgi bulabilirsiniz.

Berduş Hocam şu an Formdan kaydet tuşuna bastığımda Excel sayfalarına bilginin aktarılması çok zaman alıyor. Aynı kodları defalarca sil baştan yazdım. Dün son işlemde kayıt etmesi yaklaşık 1 dakika sürünce herşeyi sildim. Projeyi sil baştan 4.defa hiçbir kopyalama vs yapmadan adım adım yaparak ilerleyeceğim başlangıçta bir saniye süren işlem bir noktada bozuluyor ve kaydetme süresi 1 dakikaya kadar neden çıkıyor sebebini bulmam lazım. Ondan sonra bu diziler konusuna dönerim. Hız konusunda sıkıntı çıkarırsa da verileri tarihe göre büyükten küçüğe dizdirmem artık yapacak bir şey yok. Teşekkür ederim.
Access Çekirgesi 
[Resim: img-cray.gif]


Cevapla

Bir hesap oluşturun veya yorum yapmak için giriş yapın

Yorum yapmak için üye olmanız gerekiyor

ya da