İki tarih arası

Katılım
1 Ağustos 2006
Mesajlar
77
Excel Vers. ve Dili
Excel 2003 Türkçe
Arkadaşlar ekte gönderdiğim dosya için yardımcı olursanız sevinirim. Şimdiden teşekkürler.
 

N.Ziya Hiçdurmaz

Özel Üye
Katılım
28 Nisan 2007
Mesajlar
2,218
Excel Vers. ve Dili
Office 2013 TR / 32 Bit
yanıt

Kod:
Sub test()
Set s1 = Sheets("Sayfa1")
Set s2 = Sheets("Sayfa2")
s2.Range("a2:b5000").Clear
For sut = 4 To [a65536].End(xlUp).Row
If s1.Range("a" & sut) >= [a2] And s1.Range("a" & sut) <= [a3] Then
s1.Range("a" & sut & ":b" & sut).Copy
s = s2.[a65536].End(xlUp).Row + 1
s2.Range("a" & s).PasteSpecial
End If
Next
Application.DataEntryMode = False
End Sub
 
Katılım
1 Ağustos 2006
Mesajlar
77
Excel Vers. ve Dili
Excel 2003 Türkçe
İki Tarih Arası

İstediğim tam bu değil. Aktarım tamam ancak b sütununda bulunan iki tarih arası bilgilerin yazılı olduğu hücreler kopyalansın.
 
Katılım
15 Haziran 2006
Mesajlar
3,704
Excel Vers. ve Dili
Excel 2003, 2007, 2010 (TR)
Aşağıdaki kodu standart bir modül sayfasına kopyalayarak çalıştırınız.

Kod:
Sub Aktar()
Dim Sh1 As Worksheet, Sh2 As Worksheet
Dim i%, son%
Set Sh1 = Sheets("Sayfa1")
Set Sh2 = Sheets("Sayfa2")
Sh2.Range("A2:B100").ClearContents
For i = 4 To 100
    If Sh1.Cells(i, 1) >= Sh1.Cells(2, 1) And Sh1.Cells(i, 1) <= Sh1.Cells(3, 1) Then
       son = Sh2.Cells(65536, 1).End(xlUp).Row
       Sh2.Cells(son + 1, 1) = Sh1.Cells(i, 1)
       Sh2.Cells(son + 1, 2) = Sh1.Cells(i, 2)
    End If
Next i
Set Sh1 = Nothing
Set Sh2 = Nothing
End Sub
 
Katılım
1 Ağustos 2006
Mesajlar
77
Excel Vers. ve Dili
Excel 2003 Türkçe
iki tarih arası

sayın fpc sizin gönderdiğiniz kod da aynı aktarma oluyor. Ekli dosyada değişiklik yaptım sayfa1 den sayfa 2 ye aktarım yapıldıktan sonra sayfa 2 deki gibi olsun istiyorum . İlgileriniz için teşekkürler.
 
Katılım
15 Haziran 2006
Mesajlar
3,704
Excel Vers. ve Dili
Excel 2003, 2007, 2010 (TR)
Sadece bilgi içeren hücreleri aktarmak istiyorum deseniz, daha kısa sürecekti :)

Aşağıdaki kodu deneyin.

Kod:
Sub Aktar()
Dim Sh1 As Worksheet, Sh2 As Worksheet
Dim i%, son%
Set Sh1 = Sheets("Sayfa1")
Set Sh2 = Sheets("Sayfa2")
Sh2.Range("A2:B100").ClearContents
For i = 4 To 100
    If Sh1.Cells(i, 1) >= Sh1.Cells(2, 1) And Sh1.Cells(i, 1) <= Sh1.Cells(3, 1) Then
       If Trim(Sh1.Cells(i, 2)) <> Empty Then
          son = Sh2.Cells(65536, 1).End(xlUp).Row
          Sh2.Cells(son + 1, 1) = Sh1.Cells(i, 1)
          Sh2.Cells(son + 1, 2) = Sh1.Cells(i, 2)
       End If
    End If
Next i
Set Sh1 = Nothing
Set Sh2 = Nothing
End Sub
 
Katılım
1 Ağustos 2006
Mesajlar
77
Excel Vers. ve Dili
Excel 2003 Türkçe
Say&#305;n fpc te&#351;ekk&#252;r ederim istedi&#287;im oldu.
 

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
Bende hazırlamıştım.
Yabana boşa gitmesin bari.Ekli dosyayı inceleyiniz.:cool:
Kod:
Sub rapor()
Dim ilk_tarih, son_tarih, tarih As Date, sat, i As Long
Sheets("Sayfa1").Select
Sheets("Sayfa2").Range("A2:B65536").ClearContents
sat = 2
Application.ScreenUpdating = False
ilk_tarih = CDate(Range("A2").Value)
son_tarih = CDate(Range("A3").Value)
For i = 4 To Cells(65536, "A").End(xlUp).Row
    tarih = CDate(Cells(i, "A").Value)
    If tarih >= ilk_tarih And tarih <= son_tarih Then
        Sheets("Sayfa2").Cells(sat, "A").Value = CDate(tarih)
        Sheets("Sayfa2").Cells(sat, "B").Value = Cells(i, "B").Value
        sat = sat + 1
    End If
Next
Application.ScreenUpdating = True
MsgBox "İki tarih arası rapor çıkarıldı.!", vbOKOnly + vbInformation
End Sub
 
Üst