Excel Forum
ALTIN ÜYELİK Hakkında Bilgi


Geri Git   Excel Forum > EXCEL-Soruları > Makro-VBA
Atatürk
Şifremi Unuttum

DUYURU SİSTEMİ / REKLAM PANOSU

Makro-VBA Makro veya VBA ile ilgili sorularınızı buraya gönderebilirsiniz.
Dosya ekleyebilirsiniz

Özel Arama


Yanıtla
 
Paylaş Konu Araçları Görünüm Modları
Eski 08-02-2018, 11:52   #1
1Al2Ver
Altın Üye
 
1Al2Ver kullanıcısının avatarı
 
Giriş: 05/11/2007
Şehir: İstanbul / Maltepe
Mesaj: 3,643
Excel Vers. ve Dili:
Microsoft Office 365 ProPlus
Varsayılan Mevcut Kod'da Düzenleme (Veri Aktar)

Merhaba,

Yapmak istediğim,

ÇIKIŞA_AKTAR makrosu çalıştırıldığında, verileri;

Önce, "ÇIKIŞ" sayfasına aktarsın,

Sonra, KAYIT_ET () makrosunu çağırarak "MEVCUTLAR" sayfasına aktarsın,

En son, yazdırsın ve ilgili yerleri silsin.

YADA,

ÇIKIŞA_AKTAR makrosunu çalıştırınca;

Önce, "ÇIKIŞ" sayfasına aktarsın,

Sonra, "KAYIT" sayfası H1'deki tarihe göre, C3:C4 aralığını "MEVCUTLAR" sayfası "B" sütununa,

C6:16 aralığını, "MEVCUTLAR" sayfası "D" sütununa aktarsın,

En son, yazdırsın ve ilgili yerleri silsin.

Özetle, bu 2 kodu, tek bir düğme ile çalıştırmak istiyorum.

Teşekkür ederim.

Kod: (Rahat kopyalayabilmeniz için tüm kodu seçmenizi sağlar)
Sub ÇIKIŞA_AKTAR() 

Set S2 = Sheets("KAYIT"): Set s3 = Sheets("Çıkış")
ilksatır = 17: sonsatır = S2.[O60].End(3).Row: tarih = S2.[H1]
For satır = ilksatır To sonsatır
s3satır = s3.[A65536].End(3).Row + 1

    s3.Cells(s3satır, 1) = tarih: s3.Cells(s3satır, 2) = S2.Cells(satır, 2)
    s3.Cells(s3satır, 2) = S2.Cells(satır, 12): s3.Cells(s3satır, 3) = S2.Cells(satır, 13)
    s3.Cells(s3satır, 4) = S2.Cells(satır, 14): s3.Cells(s3satır, 5) = S2.Cells(satır, 15)
    
    Next
S2.Range("A1:I73").PrintOut
S2.Range("A17:I59,K17:O59,D3:D4,D6:D13,H5:H13").ClearContents
    
End Sub
KAYIT_ET () makrosu

Kod: (Rahat kopyalayabilmeniz için tüm kodu seçmenizi sağlar)
Sub KAYIT_ET()
    Set s1 = Sheets("KAYIT")
    Set s2 = Sheets("MEVCUTLAR")
    
    yeni = s2.Cells(Rows.Count, "A").End(3).Row + 1
    
    s2.Cells(yeni, "A") = s1.[H1]
    
    s1.Range("C3:C4").Copy: s2.Cells(yeni, "B").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=True
    
    s1.Range("C6:C14").Copy: s2.Cells(yeni, "D").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=True
    Application.CutCopyMode = False
    s1.Range("C3,C4,C6:C13").ClearContents
    s1.Activate
    s1.[H1].Select
    
End Sub
Eklenmiş Dosyalar
Dosya Türü: xlsm Veri Aktar 08.02.2018.xlsm (31.9 KB, 5 Görüntülenme)
__________________
Esen Kalın...
1Al2Ver Çevrimdışı   Alıntı Yaparak Cevapla
Eski 08-02-2018, 15:20   #2
YUSUF44
Destek Ekibi
 
YUSUF44 kullanıcısının avatarı
 
Giriş: 04/01/2006
Şehir: Manisa, Kula
Mesaj: 6,691
Excel Vers. ve Dili:
İş : Ofis 2016 - Türkçe Ev: Ofis 2016 - Türkçe
Varsayılan

çıkışa aktar makrosunun yazdırma satırından sonra kayıt et makrosunu çalıştırabilirsiniz:

Kod: (Rahat kopyalayabilmeniz için tüm kodu seçmenizi sağlar)
Sub ÇIKIŞA_AKTAR() 

Set S2 = Sheets("KAYIT"): Set s3 = Sheets("Çıkış")
ilksatır = 17: sonsatır = S2.[O60].End(3).Row: tarih = S2.[H1]
For satır = ilksatır To sonsatır
s3satır = s3.[A65536].End(3).Row + 1

    s3.Cells(s3satır, 1) = tarih: s3.Cells(s3satır, 2) = S2.Cells(satır, 2)
    s3.Cells(s3satır, 2) = S2.Cells(satır, 12): s3.Cells(s3satır, 3) = S2.Cells(satır, 13)
    s3.Cells(s3satır, 4) = S2.Cells(satır, 14): s3.Cells(s3satır, 5) = S2.Cells(satır, 15)
    
    Next
S2.Range("A1:I73").PrintOut
Call KAYIT_ET()
S2.Range("A17:I59,K17:O59,D3:D4,D6:D13,H5:H13").ClearContents
    
End Sub
gibi.
__________________


Sorularınızı örnek dosyayla desteklemeniz çözüme ulaşmanızı kolaylaştırır.

Altın Üye olmanızı öneririm. Altın Üye değilseniz dosyanızı dosya yükleme sitelerinden birine yükleyip linkini paylaşabilirsiniz.
YUSUF44 Çevrimdışı   Alıntı Yaparak Cevapla
Eski 08-02-2018, 20:09   #3
1Al2Ver
Altın Üye
 
1Al2Ver kullanıcısının avatarı
 
Giriş: 05/11/2007
Şehir: İstanbul / Maltepe
Mesaj: 3,643
Excel Vers. ve Dili:
Microsoft Office 365 ProPlus
Varsayılan

Sayın YUSUF44 merhaba,

Öncelikle nezaketiniz ve çözüm için teşekkür ederim,

Öğrenmek adına ;

Çıkışa_Aktar ve Kayıt_Et, makrolarını birleştirerek tek bir kod yapmak istiyorum,

Yardımcı olursanız memnun olurum.

Saygılarımla.
__________________
Esen Kalın...
1Al2Ver Çevrimdışı   Alıntı Yaparak Cevapla
Yanıtla


Konu Araçları
Görünüm Modları

Gönderme Kuralları
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is Açık
SimgelerAçık
[IMG] kodu Açık
HTML kodu Kapalı


Saat 00:38


Bu forum Elit NET - www.elitnet.com.tr tarafından sunulmaktadır.

Excel Eğitimi - Mobil Uygulama - Çorlu - Çorlu Web Tasarım -- Beylikdüzü mali müşavir - Beylikdüzü mali müşavir - Lingerie - Dyeing Machine - Karton Bardak- Karton Bardak- Çorlu Dil Konuşma Terapisti- Çorlu Dil Konuşma Terapisti- Çorlu Konuşma Terapisti- Çorlu Konuşma Terapisti- Çorlu Özel Eğitim- Site Yönetimi- Pronet Tekirdağ- Çorlu Kamera- Pronet Edirne- Pronet Çorlu- Çorlu Araç Takip- Çorlu Su Arıtma- Gebze Emlak- Rampa- Rotary- Çorlu İnternet Sitesi- Çorlu Sürücü Kursu- Çorlu Sürücü Kursu- Şişli Avukat- Edirne Serbest Muhasebeci- Çorlu Etüt- İstanbul Botanik- Çorlu Sigorta- Kağıt Bardak- Kağıt Bardak- Kaplan Tekstil- Çorlu Perde- Çorlu Perde- Çorlu Havuz- Çorlu Havuz- Makina- Danışmazlar- Çorlu Perde Yıkama- Çorlu Perde Yıkama- Okul Danışmanlık- Çorlu Ayakkabı- İzmit Sigorta- ADR'li taşıma kabı imalatı- Mekanik Tesisat- Çorlu Grafik Tasarım-
Powered by vBulletin Version 3.7.2
Copyright ©2000 - 2018, Jelsoft Enterprises Ltd.
Advertisement System V2.6 By   Branden