VBA - त्रुटि से निपटने

प्रोग्रामिंग में तीन प्रकार की त्रुटियां हैं: (ए) सिंटेक्स एरर्स, (बी) रनटाइम एरर्स और (सी) लॉजिकल एरर्स।

सिंटैक्स त्रुटियां

सिंटैक्स त्रुटियां, जिन्हें पार्सिंग त्रुटियां भी कहा जाता है, VBScript की व्याख्या के समय होती हैं। उदाहरण के लिए, निम्न पंक्ति एक सिंटैक्स त्रुटि का कारण बनती है क्योंकि यह एक बंद कोष्ठक को याद कर रही है।

Function ErrorHanlding_Demo()
   dim x,y
   x = "Tutorialspoint"
   y = Ucase(x
End Function

रनटाइम त्रुटियों

रनटाइम त्रुटियों को, अपवाद भी कहा जाता है, व्याख्या के बाद निष्पादन के दौरान होता है।

उदाहरण के लिए, निम्न पंक्ति एक रनटाइम त्रुटि का कारण बनती है क्योंकि यहां सिंटैक्स सही है लेकिन रनटाइम में यह fnmultiply को कॉल करने का प्रयास कर रहा है, जो एक गैर-मौजूदा फ़ंक्शन है।

Function ErrorHanlding_Demo1()
   Dim x,y
   x = 10
   y = 20
   z = fnadd(x,y)
   a = fnmultiply(x,y)
End Function

Function fnadd(x,y)
   fnadd = x + y
End Function

तार्किक त्रुटियां

तार्किक त्रुटियाँ नीचे ट्रैक करने के लिए सबसे कठिन प्रकार की त्रुटियाँ हो सकती हैं। ये त्रुटियाँ सिंटैक्स या रनटाइम त्रुटि का परिणाम नहीं हैं। इसके बजाय, वे तब होते हैं जब आप तर्क में एक गलती करते हैं जो आपकी स्क्रिप्ट को ड्राइव करता है और आपको अपेक्षित परिणाम नहीं मिलता है।

आप उन त्रुटियों को नहीं पकड़ सकते, क्योंकि यह आपकी व्यावसायिक आवश्यकता पर निर्भर करता है कि आप अपने कार्यक्रम में किस प्रकार का तर्क रखना चाहते हैं।

उदाहरण के लिए, किसी संख्या को शून्य या एक लिपि से विभाजित करना जो लिखी जाती है जो अनंत लूप में प्रवेश करती है।

एरर ऑब्जेक्ट

मान लें कि यदि हमारे पास रनटाइम त्रुटि है, तो त्रुटि संदेश प्रदर्शित करके निष्पादन बंद हो जाता है। एक डेवलपर के रूप में, यदि हम त्रुटि को पकड़ना चाहते हैं, तोError वस्तु का उपयोग किया जाता है।

उदाहरण

निम्नलिखित उदाहरण में, Err.Number त्रुटि संख्या देता है और Err.Description त्रुटि विवरण देता है।

Err.Raise 6   ' Raise an overflow error.
MsgBox "Error # " & CStr(Err.Number) & " " & Err.Description
Err.Clear   ' Clear the error.

गलती संभालना

VBA एक त्रुटि-हैंडलिंग दिनचर्या को सक्षम करता है और त्रुटि-हैंडलिंग दिनचर्या को अक्षम करने के लिए भी उपयोग किया जा सकता है। ऑन एरर स्टेटमेंट के बिना, कोई भी रन-टाइम त्रुटि जो घातक होती है: एक त्रुटि संदेश प्रदर्शित होता है, और निष्पादन अचानक बंद हो जाता है।

On Error { GoTo [ line | 0 | -1 ] | Resume Next }

अनु क्रमांक। कीवर्ड और विवरण
1

GoTo line

आवश्यक लाइन तर्क में निर्दिष्ट लाइन पर शुरू होने वाली त्रुटि-हैंडलिंग दिनचर्या को सक्षम करता है। निर्दिष्ट लाइन ऑन एरर स्टेटमेंट या कंपाइल-टाइम त्रुटि के समान प्रक्रिया में होनी चाहिए।

2

GoTo 0

सक्षम त्रुटि हैंडलर को वर्तमान प्रक्रिया में अक्षम करता है और इसे कुछ भी नहीं करने के लिए रीसेट करता है।

3

GoTo -1

वर्तमान प्रक्रिया में सक्षम अपवाद को अक्षम करता है और इसे कुछ भी नहीं करने के लिए रीसेट करता है।

4

Resume Next

निर्दिष्ट करता है कि जब कोई रन-टाइम त्रुटि होती है, तो नियंत्रण उस कथन के तुरंत बाद कथन पर जाता है जहां त्रुटि हुई थी, और निष्पादन उस बिंदु पर जारी है।

उदाहरण

Public Sub OnErrorDemo()
   On Error GoTo ErrorHandler   ' Enable error-handling routine.
   Dim x, y, z As Integer
   x = 50
   y = 0
   z = x / y   ' Divide by ZERO Error Raises
  
   ErrorHandler:    ' Error-handling routine.
   Select Case Err.Number   ' Evaluate error number.
      Case 10   ' Divide by zero error
         MsgBox ("You attempted to divide by zero!")
      Case Else
         MsgBox "UNKNOWN ERROR  - Error# " & Err.Number & " : " & Err.Description
   End Select
   Resume Next
End Sub