EXCEL VBA'DA GoTo İFADESİ

 

VBA'daki GoTo ifadesi bir prosedür içindeki belirli bir satıra atlar. Kod yürütmesinin programcının belirttiği belirli bir satıra atlamasına izin verir. GoTo ifadesinin sözdizimi GoTo line'dır, burada satır argümanı bir satır etiketi veya satır numarası olabilir.


VBA GoTo ifadesinin iki argümanı vardır: VBA'daki GoTo ifadesinin alt yordamdaki referansa atladığı referans ve varsayılan olarak False olarak bildirilen kaydırma işlevi. Aşağıdaki örneği ele alalım:

VBA GoTo İfadesi Giriş

Bu örnek verilen sayının bir olup olmadığını kontrol eder. Sayı 1 ise, VBA GoTo ifadesini kullanarak Satır 1'e atlar ve "Sayı 1" yazdırır, bu da yine son satıra atlanır. Çıktı, aşağıda gösterildiği gibi hemen sekmede yazdırılır.

VBA GoTo İfadesi Giriş - Çıktı

ÖNEMLİ NOKTALAR

  • VBA GoTo ifadesi, bir prosedür içindeki belirli bir satıra veya etikete kontrolü aktarmak için kullanılabilir.
  • Hata işleme amacıyla veya bir prosedür içinde belirli bir satıra veya etikete atlamak için kullanılabilir.
  • GoTo ifadesi aşırı veya yanlış kullanıldığında kodun okunmasını ve anlaşılmasını zorlaştırabilir.
  • Hata işleme amacıyla On Error ifadesiyle birlikte kullanılabilir.
  • GoTo ifadesi yalnızca göründüğü prosedür içindeki satırlara dallanabilir.
  • Akıllıca kullanılmalı ve mümkün olduğunca alternatif kontrol yapıları dikkate alınmalıdır.

Excel VBA'da GoTo İfadesini Kullanmanın 2 Yolu

GoTo ifadesini Excel VBA'da uygulamak için birçok yol kullanabilirsiniz. Burada, GoTo ifadesini Excel VBA'da kullanmanın iki ana yolunu ele alacağız. Bunlar:

  1. Application.GoTo Yöntemi
  2. Error Handler Yöntemi

1 – Application.GoTo Yöntemi

Application.GoTo metodu, Excel çalışma sayfasında imleci belirli bir hücreye taşımak ve buna dayalı çeşitli uygulamalar gerçekleştirmek için kullanılır.

Adım 1: Aşağıdaki örneği ele alalım. Burada bir alt prosedür başlatıyoruz. İmleci bir çalışma sayfasındaki belirli bir hücreye taşımak için Application.GoTo yöntemini kullanıyoruz.

VBA GoTo İfadesi - Uygulama - Adım 1

Adım 2: Kodu çalıştırdığınızda imleç belirtilen çalışma sayfasına taşınmış olacaktır.

VBA GoTo İfadesi - Uygulama - Adım 2

2 – Error Handler Yöntemi

Bir alt yordamda, kod çalıştırma işleminin hatalar nedeniyle durmasını istemediğinizde, hatalar, hata fırlatan kod bölümünü atlayarak işlenebilir. Örneğin,

Hata durumunda Sonraki'ye git

Bu satır Excel VBA'ya hatalara neden olan satırı yok saymasını ve sonraki satıra devam etmesini söyler.

Not: Bir sonraki satırın bir önceki kod satırına bağlı olması durumunda, yani hata veren kısımda, kod satırını atlamak beklenmeyen sonuçlara yol açabilir.

Adım 1: Hata İşleme'yi kullanmanız gereken bir örneği ele alalım. Burada, alt prosedür  , kodda bir hata olduğunda yürütmeyi aşağıda gösterildiği gibi  “ErrorHandler:” kısmına götürür  .

VBA GoTo İfadesi - Hata İşleyici - Adım 1

Adım 2: Kodu çalıştırın, aşağıda gösterildiği gibi bir çıktı döndürecektir.

VBA GoTo İfadesi - Hata İşleyici - Adım 2

Örnekler

Aşağıda GoTo ifadesinin kullanımını gösteren bazı örnekler bulunmaktadır.

Örnek 1

İlginç bir GoTo İfadesi örneğine bakalım. Örneğin, seçili bir aralığı bir alt dizeyle doldurmak istiyorsunuz. Hücre değeri GoTo ifadesiyle seçilebilir ve VBA MID işlevi başvurusu alt dizeyi bulabilir. Burada, şu dizeyi kullanıyoruz: "Merhaba Dünya."

VBA MID Fonksiyonu, Excel'de Application.GoTo ifadesini kullanarak dizeyi bölmek ve alt dizeyi belirli bir aralıkta yazdırmak için kullanılır. Yukarıdaki ifadeden “World” alt dizesini ediniriz ve “C7” hücresine yazdırırız. Bunu yapmanın adımları aşağıda gösterilmiştir:

Adım 1: Araç çubuğundaki “Geliştirici” bölümüne gidin ve “Visual Basic” seçeneğine tıklayın. Şimdi, VBA Editörü fonksiyonlar ve Alt prosedürler eklemek için açılır. Ardından, yeni bir modül veya boş sayfa oluşturmak için “Ekle” ve “Modül” düğmelerine tıklayın.

Geliştirici - Visual Basic
Örnek 1 - Adım 2

Adım 2: Belirtilen aralıktaki alt dizeyi yazdıracak ve bir hücreyi vurgulayacak bir alt rutin bildirin.

VBA GoTo İfadesi Örneği 1 - Adım 2

Adım 3: Orijinal dize için bir tane ve alt dize değerini depolamak için bir tane olmak üzere iki dize değişkeni bildirin.

VBA GoTo İfadesi Örneği 1 - Adım 3

Adım 4: Dize değerini bir dize girişiyle başlatın.

VBA GoTo İfadesi Örneği 1 - Adım 4

Adım 5: VBA MID Fonksiyonu referansıyla, “Dünya” kelimesini başlangıç ​​dizesinden ayırın.

VBA GoTo İfadesi Örneği 1 - Adım 5

Burada, dizeyi bölüyoruz, 7. pozisyondan başlayıp beş basamak hareket ederek alt dizemizi oluşturuyoruz. 'W' 7. pozisyonda başlıyor ve 'd' 5. pozisyonda. Dolayısıyla, ortaya çıkan alt dize "World" oluyor.

Adım 6: Tanımlanan aralıktaki alt dize değerini yazdır.

VBA GoTo İfadesi Örneği 1 - Adım 6

Adım 7: GoTo ifadesini kullanarak, içinde alt dize değeri bulunan hücreye gidin.

VBA GoTo İfadesi Örneği 1 - Adım 7

Burada, Scroll argümanı True olarak verilmiştir. GoTo ifadesinin iki argümanı vardır: reference ve scroll. Scroll, çalışma sayfasını belirtilen aralığa kadar kaydırmak ve görüntülemek için kullanılır. Çalışma sayfasını kaydırarak tam hücreyi gösterecektir. GoTo ifadesini kullanarak bir Excel Çalışma Sayfasında belirli hücre değerlerini vurgulamak faydalıdır.

Kod:

Sub GoToWithMID()
Dim myString As String
Dim subString As String
myString = “Merhaba Dünya”
subString = Mid(myString, 7, 5)
Range(“C7”).Value = subString
Application.Goto Range(“C7”), scroll:=True 
End Sub

Adım 8: Yukarıdaki kodu F5 tuşuna veya Excel araç çubuğunun üzerindeki Çalıştır düğmesine basarak çalıştırın.

VBA GoTo İfadesi Örneği 1 - Adım 8

Adım 9: Excel Çalışma Sayfasını görüntüleyin.

VBA GoTo İfadesi Örneği 1 - Adım 9

GoTo ifadesinde “Scroll” argümanını True olarak bildirdiğimizden, alt rutin “C7” hücresine “World” yazdırdı ve hücre değerini vurgulayarak oraya doğru kaydırdı.


Örnek 2

Kullanıcının belirli bir hücre değerine kaydırmak için bir prosedüre ihtiyaç duyduğu ancak geçersiz bir girdi girildiğinde kodun çalışmasını durdurmaması gereken bir örneği ele alalım. Bu, GoTo İfadesi kullanılarak yapılabilir. Aşağıda gösterilen adımlara başvurarak bunu nasıl yapacağımızı görelim:

Adım 1: Hücre değerini kaydırmak ve görüntülemek için bir alt prosedür başlatın.

Örnek 2 - Adım 1

Adım 2: Kod bir hata verdiğinde “ErrorHandler” satırına atlamak için bir GoTo ifadesi tanımlayın.

VBA GoTo İfadesi Örneği 2 - Adım 2

ErrorHandler satırı aşağıda tanımlanmıştır.

Örnek 2 - Adım 2 - Hata işleyici

Hata türünü bir mesaj kutusuna yazdırır ve ardından temizler.

Adım 3: Kullanıcıdan bir girdi aralığı kabul edin.

Örnek 2 - Adım 3

Adım 4: Aralık veri türünü başlatın ve kullanıcı tarafından verilen giriş aralığını değişkene ayarlayın.

Örnek 2 - Adım 4

Adım 5: Kullanıcının verdiği girdinin boş olup olmadığını kontrol etmek için bir If-Else ifadesi başlatın ve girdi boşsa “Geçersiz hücre adresi!” yazdırın.

Örnek 2 - Adım 5

Adım 6: Kodda hata yoksa alt prosedürden çıkılır, yoksa ErrorHandler ifadesi yürütülür.

Örnek 2 - Adım 6

Kod:

Sub GoToPracticalExample()
On Error GoTo ErrorHandler
Dim userInput As String
userInput = InputBox(“Enter a cell address:”)
Dim rng As Range
Set rng = Range(userInput)
If Not rng Is Nothing Then
Application.Goto rng, scroll:=True
Else
MsgBox “Invalid cell address!”
End If
Exit Sub
ErrorHandler:
MsgBox “An error occurred: ” & Err.Description
Err.Clear
End Sub

Adım 7: Yukarıdaki kodu F5 tuşuna veya Excel VBA araç çubuğundaki yeşil ok tuşuna basarak çalıştırın.

Örnek 2 - Adım 7

Adım 8: Çıktı aşağıda gösterildiği gibidir.

Örnek 2 - Adım 8
Örnek 2 - Adım 8 - Çıktı

Eğer geçersiz bir girdi verilirse, aşağıda gösterildiği gibi şunu elde ederiz:

Örnek 2 - Adım 8 - Geçersiz Giriş
Örnek 2 - Adım 8 - Hata

Bu, GoTo ifadesi kullanılarak Hata İşlemenin Excel VBA'da nasıl kullanıldığına dair bir örnektir.

Dikkat Edilmesi Gereken Önemli Noktalar

  • GoTo ifadesi gerektiğinde hata işleme amacıyla kullanılabilir.
  • Kodun okunabilirliğini ve sürdürülebilirliğini artırdığında GoTo ifadesini kullanın.
  • GoTo ifadesinin aşırı, gereksiz veya kafa karıştırıcı kullanımından kaçının. Örneğin, kodun okunabilirliğini azalttığı ve ek hatalara neden olabileceği için GoTo işlevini kod satırlarını atlamak için kullanmayın.
  • GoTo ifadesini yanlış kullanarak “spagetti kod” oluşturmayın.
  • Kodunuzda birincil kontrol yapısı olarak GoTo ifadesini kullanmaktan kaçınmak en iyisidir.

Yorum Gönder

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