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