EXCEL VBA'DA KOD NASIL YAZILIR

 

VBA kodu, sıfırdan yazılan, insan tarafından okunabilen ve düzenlenebilen bir programlama dilidir, aksi takdirde Excel, bir makro kaydettiğimizde kendi kodunu üretir. VBA makrolarını kullanarak, Excel'deki tüm zor görevleri otomatikleştirebiliriz.


VBA, Microsoft tarafından Office Uygulamaları için oluşturulmuş bir programlama dilidir. Excel'de düzenli olarak çok fazla manuel iş yaparız. Bu, önemli miktarda zaman alır ve üretkenliği etkiler. Bu nedenle, Excel'de görevleri otomatikleştirebilen VBA adlı bir otomasyon kodlama dilimiz vardır


ÖNEMLİ NOKTALAR

  • VBA (Visual Basic for Applications) kodu kolaylıkla yazabileceğimiz, okuyabileceğimiz ve düzenleyebileceğimiz programlama kodudur.
  • VBA makrolarını kullanmak görevleri otomatikleştirmemize ve muazzam miktarda zaman ve iş tasarrufu yapmamıza yardımcı olur.
  • Makro Kaydet seçeneği Excel'de yapılan tüm işlemleri kaydedecek ve VBA kodu oluşturacaktır.
  • VBA Makro kodları satır satır çalıştırılır.
  • VBA kodu oluşturulduktan sonra çalışma kitabını “Makro Etkin Çalışma Kitabı” olarak kaydetmemiz gerekir.

Geliştirici Sekmesini Etkinleştir

Visual Basic for Applications , Excel'deki Geliştirici sekmesi altında mevcuttur . Aşağıdaki görüntü, Excel'deki Geliştirici sekmesi altında Visual Basic'i göstermektedir.

Vba Kodu - Geliştirici sekmesi

Ancak bazen Geliştirici sekmesini göremeyebiliriz . Aşağıdaki adımlar Geliştirici sekmesini etkinleştirmeniz için size rehberlik edecektir.

Adım 1: Dosya sekmesine gidin .

Vba Kodu - Geliştirici sekmesi - adım 1

Adım 2: Seçenekler'e tıklayın .

Vba Kodu - Geliştirici sekmesi - adım 2

Adım 3: Bu Excel Seçenekleri penceresini getirecektir . Excel Şeridini Özelleştir'e tıklayın .

Vba Kodu - Geliştirici sekmesi - adım 3

Adım 4: Ana Sekme altında Geliştirici sekmesi kutusunu işaretleyin .

Vba Kodu - Geliştirici sekmesi - adım 4

Adım 5: Tamam'a tıklayın . Şimdi Geliştirici sekmesini görebileceğiz Geliştirici sekmesinin altında Makrolar var.

Vba Kodu - Geliştirici sekmesi - adım 5

Excel'de VBA Kodu Nasıl Yazılır?

VBA'da yeni başlayan biri olarak, VBA kodunu sıfırdan anlamak zordur. Ancak yolculuğumuza başlamak için Record Macro adlı bir seçeneğimiz var.

Makro Kaydet, Excel'de gerçekleştirdiğimiz tüm aktiviteleri kaydetmek için Excel'de bulunan bir özelliktir. Tüm aktiviteleri yakalayan bir kayıt cihazı gibidir. Makro Kaydetme, Geliştirici sekmesi altında mevcuttur.

Vba Kodu - Makro Kaydet

Size bir makronun kaydedilmesi ve kodun okunmasına dair basit bir örnek göstereceğiz.

Adım 1: Geliştirici sekmesine gidin ve Makro Kaydet seçeneğine tıklayın .

Vba Kodu - Makro Kaydet - adım 1

Adım 2: Aşağıdaki gibi Makro Kaydet penceresi açılacaktır .

Vba Kodu - Makro Kaydet - Adım 2

Adım 3: Makroya bir isim verin. Bir makroya isim verirken lütfen aşağıdaki ölçütlere bakın.

Vba Kodu - Makro Kaydet - Adım 3 - Hatırla
Vba Kodu - Makro Kaydet - Adım 3 - Deneme makrosu

Adım 4: Tamam'a tıklayın ve kayıt başlar. Şimdi Excel tüm aktiviteleri kaydedecek ve bunları VBA kodunda saklayacaktır.

İlk yapacağımız aktivite A1 hücresini seçmektir.

Vba Kodu - Makro Kaydet - Adım 4

Adım 5: Seçili hücreye İlk Makrom metnini girin .

Vba Kodu - Makro Kaydet - Adım 5

Adım 6: Hala A1 hücresindeyiz. Metni girdikten sonra Enter tuşuna basın, aşağıdaki hücre yani A2 hücresi seçilecektir.

Vba Kodu - Makro Kaydet - Adım 6

Görüldüğü gibi A2 hücresi seçilmiştir.

Adım 7: Şimdi tekrar A1 hücresini seçin ve aşağıdaki biçimlendirmeyi uygulayın.

Font Name = Times New Roman

Font Size (Yazı Boyutu) = 14

Font Color (Yazı Tipi Rengi) = Blue (Mavi)

Font Style (Yazı Tipi Stili) = Bold (Kalın)

Vba Kodu - Makro Kaydet - Adım 7

Adım 8: VBA'ya başlamak için bu aktiviteler yeterlidir. Geliştirici sekmesi altında Kaydı Durdur'a tıklayın .

Vba Kodu - Makro Kaydet - adım 8

Artık kayıt durduruldu ve hiçbir aktivite kaydedilmeyecek.

Makroyu Çalıştır

Adım 1: A1 hücresindeki değeri silin ve başka bir değer seçin.

Vba Kodu - kodu yürüt - adım 1

Adım 2: Geliştirici sekmesine gidin ve Makrolar seçeneğine tıklayın .

Vba Kodu - kodu yürüt - adım 2

Adım 3: Bu, tüm makroların listesinin olduğu Makro penceresini getirecektir . Makroyu kaydederken verdiğimiz makro adını seçin, yani Trial_Macro ve OK'e tıklayın .

Vba Kodu - kodu yürüt - adım 3

Tamam'a tıkladığımız anda kayıt sırasında yaptığımız tüm işlemler yapılacak ve A1 hücresinde yazıyı görebileceğiz.

Vba Kodu - kodu yürüt - adım 3-çıktı

Kodu Anlayın

Kayıt, VBA'daki kodlar aracılığıyla yapılır. Tüm aktivitelerin kodlarını görüntülemek için Visual Basic Editor penceresine gitmemiz gerekir.

Geliştirici sekmesine gidin ve Visual Basic seçeneğine tıklayın .

Vba Kodu - Visual Basic

Bu, aşağıda gösterildiği gibi Visual Basic Düzenleyici penceresini açacaktır.

Not: Visual Basic Editor penceresini açmak için kısayol tuşları ALT + F11'dir.

Vba Kodu - Visual Basic Editörü

Kodu görmek için Module1'e çift tıklayın .

Vba Kodu - Modül1

İlk bakışta kod size yabancı gelebilir, ancak gelin size basit bir şekilde açıklayalım.

İlk kelime Sub Record_Macro'dur .

SUB, makro adını başlatan kelimedir. Bu nedenle, bu kelimeyi mavi renkte görebiliriz.

Makroyu kaydederken yaptığımız ilk şey makroya bir isim vermekti, yani, Trial_Macro . Böylece, Excel bunu programın başlangıcı olarak kabul eder, bu yüzden program Sub kelimesiyle başlar ve ardından makro adı gelir, yani, Record_Macro .

Vba kodu - İlk Eylem

Kayıt başladıktan sonra A1 hücresini seçtik ve Excel bunu Aralık(“A1”) olarak kaydetti.Seç

Vba kodu - İkinci Eylem

A1 hücresini seçtikten sonra İlk Makrom değerini girdik. A1 hücresini ActiveCell olarak kaydetmiştir çünkü A1 hücresini seçtiğimiz anda aktif bir hücre haline gelmiştir. VBA bunu aktif bir hücre olarak ele alır; dolayısıyla A1 hücresi aktif bir hücredir.

Vba kodu - Üçüncü Eylem

Sonra, biçimlendirmek için yine A1 hücresini seçtik, bu nedenle bunun için VBA kodu Range(“A1”).Select

Vba kodu - Dördüncü Eylem

A1 hücresi seçildikten sonra bazı biçimlendirmeler uyguladık, bu nedenle VBA bunu birden fazla parçaya ayırdı.

vba kodu - Diğer Eylemler

Birkaç satır kod tek bir bloğa kısaltılabilir. Aşağıda kısaltılmış kod bulunmaktadır.

Kırpılmış kod

Tüm dört biçimlendirme görevi artık tek bir blok altında. Yani, genel kod şu şekilde okunur.

genel kod

Daha İyi Anlamak İçin Makroyu Satır Satır Çalıştırın

VBA makro satırlarının nasıl çalıştığını anlamak için, bunları satır satır yürütmeliyiz. A1 hücresindeki değeri silin ve başka bir hücreyi seçin.

Makroyu çalıştır Satır 1

ALT + F11 kısayol tuşunu kullanarak Visual Basic Editor'ı açalım , aşağıdaki görüntüdeki gibi bir kod penceresi göreceğiz.

Makroyu çalıştır Satır 2

İmleci makronun içine getirin ve kısayol tuşu olan F8'e basın .

Makroyu yürüt Satır - 1. yürütme

Gördüğümüz gibi, makronun ilk satırı sarı renkle vurgulanmıştır. Bu, bu satırın yürütülmek üzere olduğu anlamına gelir; bu nedenle, makronun çalışmasını başlatmak için F8 tuşuna basın.

Makroyu yürüt Satır - 2. yürütme

Makronun ilk satırı Range(“A1”).Select'tir , yani geçerli çalışma sayfasındaki A1 hücresini seçecektir. Şu anda etkin hücre B3'tür; bu nedenle bu satırı yürütmek için F8 tuşuna basın ve A1 hücresi seçilecektir.

Makroyu yürüt Satır - 3. yürütme

Bir sonraki satır A1 hücresine İlk Makrolarım değerini ekleyecektir . Bu satırı yürütmek için F8 tuşuna basın.

Makroyu yürüt Satır - 4. yürütme
  • Daha sonra tekrar A1 hücresini seçecektir. Bu satırı çalıştırmak için F8 tuşuna basın.
  • Bir sonraki satır FONT özelliği için WITH ifadesini başlatacaktır.
  • Yazı tipi adını Times New Roman olarak değiştirecektir .
Makroyu yürüt Satır - 5. yürütme

Daha sonra yazı tipi boyutunu 14'e değiştirecektir.

Makroyu yürüt Satır - 6. yürütme

Daha sonra çizginin rengi MAVİ'ye dönüşecektir (VBA Kayıt Makrosu'nda mavi renk bu sayı ile temsil edilir -4165632).

Makroyu yürüt Satır - 7. yürütme

Daha sonra satır yazı tipini Kalın yapacaktır .

Makroyu yürüt Satır - 8. yürütme

Bu şekilde VBA makro kodları satır satır çalıştırılır.

VBA Kod Örnekleri

Örnek 1: Sıfırdan Kendi Kodunuzu Yazın

VBA kodunu sıfırdan kendi başınıza yazmanız için size rehberlik edelim. Aşağıdaki şeyleri otomatikleştirmemiz gerektiğini varsayalım.

  • Görev 1: A1:B5 aralığındaki verileri kopyalayın.
  • Görev 2: Kopyalanan verileri D1:E5 aralığına yapıştırın.
  • Görev 3: A1:B5 aralığındaki verileri silin.

Kodu yazmak için Excel'de şu verilerimiz var.

Vba Kod örnekleri

Daha sonra Excel'de ALT + F11 kısayol tuşlarına basarak Visual Basic Editor penceresini hızlıca açın .

Adım 1: Makroyu başlatmak için “SUB” anahtar kelimesini ve ardından makro adını girin.

Örnekler 1- adım 1

Adım 2: Enter tuşuna basın , otomatik olarak “End Sub” gelecektir.

Örnekler 1- adım 2

Adım 3: SUB ve END SUB arasına kodumuzu yazmalıyız.

Sonra, yapmamız gereken ilk iş A1:B5 aralığını kopyalamaktır. Bu nedenle, bu hücre aralığını seçmek için VBA'daki RANGE özelliğini kullanmalıyız .

örnekler 1- adım 3

Adım 4: Çift tırnak içindeki hücre aralığını aşağıdaki gibi girin.

örnekler 1- adım 4

Adım 5: Girilen aralıkta kopyalama yapmalı ve RANGE özelliğinin IntelliSense özellik ve metot listesini almak için bir nokta (.) girmeliyiz.

örnekler 1- adım 5

Noktaya girdiğimiz anda VBA IntelliSense listesi bize RANGE özelliğinin özelliklerini ve metodlarını gösterdi.

Adım 6: Listeden kopyalama yöntemini seçin.

örnekler 1- adım 6

Adım 7: Bu, A1:B5 aralığını kopyalayacaktır. Sonra, kopyalanan verileri “D1:E5” aralığına yapıştırmamız gerekir, bu yüzden tekrar RANGE özelliğine girin ve yapıştırma alanına girin.

örnekler 1- adım 7

Adım 8: Verilen aralıkta yapıştırma yapmamız gerekiyor, bu nedenle “özel yapıştır” yöntemini seçiyoruz.

örnekler 1- adım 8

Adım 9: Görev #3, A1:B5 aralığındaki değerleri silmektir. Yani tekrar aralık özelliğine girin ve “Clear” yöntemini seçin.

Vba Kod örnekleri - adım 9

Daha sonra F5 tuşuna basarak bu kodu çalıştırdığımızda aşağıdaki sonucu elde edeceğiz.

Vba Kod örnekleri - Çıktı

Bu şekilde kendi makrolarımızı sıfırdan yazabiliriz.

Örnek 2: Tüm Çalışma Sayfalarını Gizle

Aşağıdaki kod, “Sheet1” çalışma sayfası haricindeki tüm çalışma sayfalarını gizlemenize yardımcı olacaktır.

Vba Kodu - Örnek 2

Yukarıdaki kodu kopyalayıp Visual Basic Editor penceresine yapıştırın.

Örnek 2 - Kod

Bu kodu çalıştırdığınızda, çalışma kitabınızdaki "Sheet1" adlı çalışma sayfası hariç tüm çalışma sayfaları gizlenecektir.

Örnek 3: Tüm Çalışma Sayfalarını Göster

Benzer şekilde, tüm çalışma sayfalarını görünür kılmak istiyorsak, aşağıdaki kodu kullanabiliriz.

Örnek 3 - Tüm Çalışma Sayfalarını Göster

Yukarıdaki kod tüm gizli çalışma sayfalarını görünür hale getirecektir.

Örnek 3 - Kodu gizle

VBA Makro Çalışma Kitabını Kaydetme

Makro kaydı tamamlandıktan sonra yapmamız gereken bir diğer önemli şey ise çalışma kitabını Makro Etkin Çalışma Kitabı dosya uzantısı olarak kaydetmektir.

VBA kodunu oluşturduktan sonra Kaydet butonuna tıkladığımızda karşımıza aşağıdaki komut gelecektir.

VBA Makro Çalışma Kitabını Kaydetme

Daha önce kaydedilmiş dosya sürümleri olan XLSX nedeniyle, bu dosyada makro kodunu oluşturduğumuzda, "Aşağıdaki özellikler makro etkinleştirilmiş çalışma kitaplarına kaydedilemez." uyarı mesajını veriyor.

Bunu kaydedebilmek için dosyayı “Excel Makro Etkin Çalışma Kitabı” dosya türüyle kaydetmemiz gerekiyor.

Dosya türünü kaydet

Dosyayı “Excel Makro Etkin Çalışma Kitabı” dosya türünde kaydettiğimizde, normal dosya uzantısı ile makro dosya uzantısı arasında bir simge farkı göreceğiz.

Dosya Uzantısı

XLSM makro dosyası, XLSX ise makro olmayan dosyadır.

Dikkat Edilmesi Gereken Önemli Noktalar

  • VBA, Visual Basic for Applications'ın kısaltmasıdır.
  • Excel'de geliştirici sekmesi varsayılan olarak gizlidir.
  • Makro adı sayısal bir değerle başlamamalı ve alt çizgi (_) karakteri dışında herhangi bir boşluk veya özel karakter içermemelidir.
  • ALT + F11, Visual Basic Editor penceresini başlatmak için kullanılan kısayol tuşudur.
  • Sıfırdan makro yazarken IntelliSense listesini görmek için kısayol tuşu Ctrl + Space'tir.
  • F8, makro kodlarını satır satır çalıştırmaya yarayan kısayol tuşudur.


Yorum Gönder

DT KARİYER KPSS Dünyasına Hoş Geldiniz
Sevgili dostum nasıl yardımcı olabilirim?
Bu alana yazınız...