આ ટ્યુટોરીયલ પ્રોગ્રામિંગ ઉદાહરણોની મદદથી ટ્રાય એક્સેપ્ટ બ્લોકનો ઉપયોગ કરીને પાયથોનમાં અપવાદ હેન્ડલિંગને સમજાવે છે:
બે ભૂલ પ્રકારો પાયથોન પ્રોગ્રામને અચાનક બંધ કરી શકે છે એટલે કે સિન્ટેક્સ ભૂલો , અને અપવાદો . આ ટ્યુટોરીયલમાં, અમે ઘણા મહત્વપૂર્ણ વિષયો હેઠળ બીજા ભૂલ પ્રકાર (અપવાદો) ની ચર્ચા કરીશું.
અમને અમારી એપ્લિકેશનમાં અપવાદોને હેન્ડલ કરવાથી ઘણો ફાયદો થશે જેમ કે:
- એક મજબૂત એપ્લિકેશન બનાવવી.
- શુદ્ધ અને ભૂલ-મુક્ત કોડ બનાવવો.
પાયથોન અજમાવી જુઓ
એક સારા સમાચાર એ છે કે અમારા કોડમાં ભૂલો પકડવા માટે પાયથોન પાસે બિલ્ટ-ઇન અપવાદોની સારી સંખ્યા છે. ઉપરાંત, જ્યારે બિલ્ટ-ઇન અપવાદોમાંથી કોઈ પણ આપણી જરૂરિયાતોને અનુરૂપ ન હોય ત્યારે તે અમને કસ્ટમ અપવાદો બનાવવાની તક આપે છે.
અપવાદ શું છે
તો પાયથોનમાં અપવાદ શું છે? ઠીક છે, સાદા શબ્દોમાં, જ્યારે પણ પાયથોન દુભાષિયા અમાન્ય કોડનો અમલ કરવાનો પ્રયાસ કરે છે, ત્યારે તે એક અપવાદ ઉભો કરે છે, અને એવા કિસ્સાઓમાં જ્યાં આવા અપવાદને નિયંત્રિત કરવામાં આવતો નથી, તે પ્રોગ્રામની સૂચનાઓના સામાન્ય પ્રવાહમાં વિક્ષેપ પાડે છે અને ટ્રેસબેક છાપે છે.
ચાલો એક અમાન્ય કોડ બનાવીએ અને જોઈએ કે પાયથોન ઈન્ટરપ્રીટર કેવી રીતે પ્રતિસાદ આપશે.
પાયથોન શેલ ખોલો અને નીચેનો કોડ ચલાવો.
>>> 50/0
આ એક છે. પ્રોગ્રામિંગમાં સૌથી સામાન્ય ભૂલો. ઉપરનો કોડ નંબર 50 ને 0 (શૂન્ય) વડે વિભાજીત કરવાનો પ્રયાસ કરે છે. અજગરચલ ઓપનફાઇલ તે સોંપવામાં આવે તે પહેલાં.
અહીં એક નાની યુક્તિ એ છે કે ફાઈનલી-બ્લોકની અંદર અપવાદ હેન્ડલરનો ઉપયોગ કરવો.
def readFile(file_path): try: openFile = open(file_path,'r') # Open a file as read-only print(openFile.readline()) # Read first line of file content except FileNotFoundError as ex: print(ex) finally: try: print("Cleaning...") openFile.close() except: # catches all exceptions pass # Ignore this error because we don't care. if __name__ == '__main__': filePath = './text.txt' readFile(filePath)
જો અમારું ટ્રાય-બ્લોક FileNotFoundError ને વધારે છે, તો આપણી પાસે નીચેનું આઉટપુટ હશે
Raise Exception
Python અપવાદો વિશે એક સારા સમાચાર એ છે કે આપણે જાણી જોઈને તેમને ઉભા કરો. અપવાદોને રેઝ સ્ટેટમેન્ટ સાથે ઉભા કરવામાં આવે છે.
રાઇઝ સ્ટેટમેન્ટમાં નીચેનું સિન્ટેક્સ હોય છે:
raise [ExceptionName[(*args: Object)]]
ટર્મિનલ ખોલો અને માંથી કોઈપણ અપવાદ ઑબ્જેક્ટ ઉભા કરો પાયથોન ઇન-બિલ્ટ અપવાદો. ઉદાહરણ તરીકે, જો આપણે ZeroDivisionError વધારીએ:
>>> raise ZeroDivisionError("Can't divide by zero")
અમને ટ્રેસબેક મળશે:
તેથી, અપવાદો ઉભા કરવા શા માટે મહત્વપૂર્ણ છે?
- કસ્ટમ અપવાદો સાથે કામ કરતી વખતે.
- સેનિટી તપાસ દરમિયાન.
કસ્ટમ અપવાદ વર્ગો
એક કસ્ટમ અપવાદ એ છે કે જે તમે તમારી જરૂરિયાતને અનુરૂપ ભૂલોને નિયંત્રિત કરવા માટે બનાવો છો. યુક્તિ એ છે કે, અમે એક વર્ગને વ્યાખ્યાયિત કરીએ છીએ જે ઑબ્જેક્ટ અપવાદ માંથી ઉતરી આવે છે, પછી અમે અમારા અપવાદ વર્ગને વધારવા માટે raise સ્ટેટમેન્ટનો ઉપયોગ કરીએ છીએ.
ધારો કે આપણે વપરાશકર્તાના ઇનપુટને તપાસવા માંગીએ છીએ અને ખાતરી કરીએ છીએ. ઇનપુટ મૂલ્ય નકારાત્મક નથી (સેનિટી ચેક). અલબત્ત, અમે પાયથોન અપવાદ ValueError વધારી શકીએ છીએ પરંતુ અમે તેને InputIsNegativeError જેવું ચોક્કસ અને સ્વ-સ્પષ્ટીકરણ નામ આપીને ભૂલને કસ્ટમાઇઝ કરવાનું પસંદ કરીશું. પરંતુ આ અપવાદ એ પાયથોન ઇન-બિલ્ટ નથીઅપવાદ.
તેથી પ્રથમ, અમે અમારો આધાર વર્ગ બનાવીએ છીએ જે અપવાદમાંથી મેળવશે.
class CustomError(Exception): "Base class exception for all exceptions of this module" pass
પછી આપણે આપણો અપવાદ વર્ગ બનાવીએ છીએ જે આધાર વર્ગને વારસામાં મેળવશે અને અમારી ચોક્કસ ભૂલને સંભાળશે.
class InputIsNegativeError(CustomError): """Raised when User enters a negative value""" pass
ચાલો આનું પરીક્ષણ કરીએ
try: value = int(input()) if value 0: raise InputIsNegativeError # Raise exception if value is negative except InputIsNegativeError: # catch and handle exception print("Input value shouldn't be negative")
વપરાશકર્તા ઇનપુટ માટે ઉપરોક્ત કોડ વિનંતી, અને તપાસો કે શું તે નકારાત્મક છે. જો સાચું હોય, તો તે અમારા કસ્ટમ અપવાદ InputIsNegativeErrorને વધારે છે જે બાદમાં સિવાય-સ્ટેટમેન્ટમાં પકડાય છે.
નીચે સંપૂર્ણ કોડ છે:
class CustomError(Exception): "Base class exception for all exceptions of this module" pass class InputIsNegativeError(CustomError): """Raised when User enters a negative value""" pass if __name__ == '__main__': try: value = int(input("Input a number: ")) if value 0: raise InputIsNegativeError # Raise exception if value is negative except InputIsNegativeError: # catch and handle exception print("Input value shouldn't be negative")
જો ઇનપુટ મૂલ્ય -1 જેવી નકારાત્મક સંખ્યા છે, તો આપણી પાસે આઉટપુટ હશે:
Python કસ્ટમ અપવાદો પર વધુ વિગતો માટે Python દસ્તાવેજ તપાસો.
વારંવાર પૂછાતા પ્રશ્નો
પ્ર #1) પાયથોન અપવાદને કેવી રીતે હેન્ડલ કરે છે?
જવાબ: પાયથોન નો ઉપયોગ કરીને અપવાદોને હેન્ડલ કરે છે. પ્રયાસ-સિવાય નિવેદન . કોડ કે જે અપવાદ ઉભા કરી શકે છે તે પ્રયાસ બ્લોક માં મૂકવામાં આવે છે અને ચલાવવામાં આવે છે જ્યારે બ્લોક સિવાય કોડ ધરાવે છે જે જો કોઈ ઉદ્ભવે તો અપવાદોને સંભાળશે.
પ્ર #2) પાયથોનમાં અપવાદ શું છે?
જવાબ: જ્યારે પણ પાયથોન ઈન્ટરપ્રીટર અમાન્ય કોડનો સામનો કરે છે, ત્યારે તે અપવાદ ઉભો કરે છે, જે પાયથોનની પોતાની રીતે છે. અમને કહેવા માટે કે કંઈક અણધાર્યું થયું. અમે રાઇઝ સ્ટેટમેન્ટ નો ઉપયોગ કરીને ઇરાદાપૂર્વક અપવાદો વધારી શકીએ છીએ.
પ્ર #3) પાયથોન બહુવિધ અપવાદોને કેવી રીતે હેન્ડલ કરે છે?
જવાબ: Python બહુવિધ અપવાદોને હેન્ડલ કરે છેબ્લોક સિવાય એક અથવા બહુવિધ બ્લોક્સનો ઉપયોગ કરીને.
એક બ્લોક માટે, અપવાદો ટ્યુપલ તરીકે પસાર થાય છે: સિવાય (અપવાદ1, અપવાદ2,..,અપવાદN) અને પાયથોન તપાસો જમણેથી ડાબે મેચ માટે. આ કિસ્સામાં, દરેક અપવાદ માટે સમાન પગલાં લેવામાં આવે છે.
બધા અપવાદોને પકડવાની બીજી રીત એ છે કે અપવાદના નામ સિવાયના કીવર્ડ પછી છોડી દેવો.
except: # handle all exceptions here
બીજી રીત છે. દરેક અપવાદ માટે એક સિવાયના બ્લોકનો ઉપયોગ કરવા માટે:
except Exception1: # code to handle Exception1 goes here except Exception2: # code to handle Exception2 goes here except ExceptionN: # code to handle ExceptionN goes here
આ રીતે, તમે દરેક અપવાદ માટે અલગ-અલગ પગલાં લઈ શકો છો.
પ્ર #4) પાયથોનમાં અપવાદનું સંચાલન શા માટે મહત્વનું છે?
જવાબ: પાયથોનમાં અપવાદોને હેન્ડલ કરવાનો ફાયદો એ છે કે આપણે મજબૂત, સ્વચ્છ અને ભૂલ-મુક્ત એપ્લિકેશનો બનાવી શકીએ છીએ. અમે નથી ઈચ્છતા કે અમારો પ્રોડક્શન કોડ કેટલીક ભૂલોને કારણે ક્રેશ થાય, તેથી અમે ભૂલોને હેન્ડલ કરીએ છીએ અને અમારી એપ્લિકેશનને ચાલુ રાખીએ છીએ.
પ્ર #5) તમે પાયથોનમાં અપવાદને કેવી રીતે અવગણશો?
જવાબ: Python માં અપવાદને અવગણવા માટે, બ્લોક સિવાયના pass કીવર્ડનો ઉપયોગ કરો. ચાલો કહીએ કે અમે ValueError અપવાદને અવગણવા માંગીએ છીએ. અમે તેને આ રીતે કરીશું:
except ValueError: pass
જ્યાં સુધી તમે જાણતા ન હોવ કે તમે શું કરી રહ્યાં છો, અપવાદોને અવગણવા એ ખરાબ પ્રથા છે. ઓછામાં ઓછું, તમામ સંભવિત ભૂલો વિશે વપરાશકર્તાને જાણ કરો.
નિષ્કર્ષ
આ ટ્યુટોરીયલમાં, અમે આવરી લીધું છે: પાયથોન અપવાદો, ટ્રેસબેક; પ્રયાસ કરો / સિવાય / અન્ય / છેવટે સાથે અપવાદોને કેવી રીતે હેન્ડલ કરવુંબ્લોક્સ, અપવાદો કેવી રીતે વધારો અને છેલ્લે આપણા પોતાના કસ્ટમ અપવાદો કેવી રીતે બનાવવો.
વાંચવા બદલ આભાર!
દુભાષિયા આને અમાન્ય કામગીરી તરીકે જુએ છે અને ZeroDivisionErrorઉભા કરે છે, પ્રોગ્રામને વિક્ષેપિત કરે છે, અને ટ્રેસબેક છાપે છે.
અમે સ્પષ્ટપણે જોઈ શકીએ છીએ કે ZeroDivisionError એ અપવાદ છે જે ઉભો કરવામાં આવ્યો હતો. તે ખરેખર પાયથોનની પોતાની રીત છે જે અમને જણાવે છે કે સંખ્યાને શૂન્યથી વિભાજિત કરવી તે સરસ નથી. જોકે JavaScript જેવી અન્ય ભાષાઓમાં, આ કોઈ ભૂલ નથી; અને પાયથોન આ પ્રથાને સખત રીતે પ્રતિબંધિત કરે છે.
ઉપરાંત, એ જાણવું અગત્યનું છે કે આ માત્ર એક અપવાદ ઓબ્જેક્ટ છે અને પાયથોન પાસે આવા ઘણા ઓબ્જેક્ટ્સ ઇન-બિલ્ટ છે. તમામ પાયથોન બિલ્ટ-ઇન અપવાદો જોવા માટે આ પાયથોન ઓફિશિયલ ડોક્યુમેન્ટેશન તપાસો.
ટ્રેસબેકને સમજવું
અમે અપવાદોને હેન્ડલ કરીએ તે પહેલાં, મને લાગે છે કે જો અપવાદો હોય તો બરાબર શું થશે તે સમજવામાં મદદ કરશે. હેન્ડલ કરવામાં આવતું નથી અને કેવી રીતે પાયથોન અમારી ભૂલ વિશે અમને જાણ કરવા માટે શ્રેષ્ઠ પ્રયાસ કરે છે.
જ્યારે પણ પાયથોન કોઈ ભૂલનો સામનો કરે છે, ત્યારે તે એક અપવાદ ઉભો કરે છે. જો આ અપવાદને નિયંત્રિત કરવામાં ન આવે, તો તે ટ્રેસબેક નામની કેટલીક માહિતી ઉત્પન્ન કરે છે. તો, આ ટ્રેસબેકમાં કઈ માહિતી શામેલ છે?
તેમાં શામેલ છે:
- ભૂલ સંદેશ જે અમને જણાવે છે કે કયો અપવાદ ઉભો કરવામાં આવ્યો હતો અને આ અપવાદ પહેલા શું થયું હતું ઉઠાવવામાં આવ્યો.
- કોડના વિવિધ લાઇન નંબરો જેના કારણે આ ભૂલ થઈ. કૉલ સ્ટેક નામના ફંક્શન કૉલ્સના ક્રમને કારણે ભૂલ આવી શકે છે જેની અમે અહીં પછીથી ચર્ચા કરીશું.
જો કે તેથોડી ગૂંચવણભરી, અમે વચન આપીએ છીએ કે આગળનું ઉદાહરણ અમારી સમજણમાં વધુ પ્રકાશ લાવશે.
ઉપર 50 દ્વારા 0 ને વિભાજિત કરવાથી પ્રિન્ટ થયેલ ટ્રેસબેકને યાદ કરો, આપણે જોઈ શકીએ છીએ કે ટ્રેસબેકમાં નીચેની માહિતી શામેલ છે:
- ફાઇલ “”: આ અમને જણાવે છે કે આ કોડ કન્સોલ ટર્મિનલ પરથી ચલાવવામાં આવ્યો હતો.
- લાઇન 1: આ અમને જણાવે છે કે આ લાઇન નંબરમાં ભૂલ આવી છે.
- ઝીરો ડિવિઝન એરર: શૂન્ય દ્વારા વિભાજન: તે અમને જણાવે છે કે કયો અપવાદ ઉભો થયો હતો અને તેનું કારણ શું હતું.
ચાલો બીજું ઉદાહરણ અજમાવી જુઓ અને કદાચ જુઓ કે કોલ સ્ટેક કેવો દેખાય છે. એડિટર ખોલો, નીચેનો કોડ દાખલ કરો અને tracebackExp .py
def stack1(numb): # 1 div = 0 # 2 stack2(numb, div) # 3 def stack2(numb, div): # 5 compute = numb/div # 6 print(compute) # 7 if __name__ == '__main__': # 9 numb = 5 # 10 stack1(numb) # 11
એક ટર્મિનલ ખોલો જ્યાં આ ફાઇલ મળે છે અને ચલાવો.
python tracebackExp.py
તમે નીચેનું ટ્રેસબેક જોશો:
ઉપરનું ટ્રેસબેક ગૂંચવણભર્યું લાગે છે પરંતુ ખરેખર એવું નથી. પાયથોનિસ્ટાસ ટ્રેસબેક વાંચવાની શ્રેષ્ઠ રીત સાથે આવ્યા છે, જે બોટમ અપ થી છે. તેથી, ચાલો આ ડહાપણનો ઉપયોગ કરવાનો પ્રયાસ કરીએ અને સમજવા માટે કે આ ટ્રૅસબેક શું ઑફર કરે છે.
- સૌથી નીચે, આપણને અપવાદ મળે છે કે જે ઉછેરવામાં આવ્યો હતો અને તે શા માટે ઉછેરવામાં આવ્યો હતો.
- ઉપર જતાં, અમને ફાઈલનું નામ tracebackExp .py મળે છે જ્યાં આ ભૂલ આવી હતી, આ ભૂલનું કારણ બનેલી ગણતરી = numb/div, ફંક્શન સ્ટેક2, અને લિંક નંબર લાઇન 6 જ્યાં આ ગણતરી કરવામાં આવી હતી. .
- ઉપર જઈને, આપણે જોઈએ છીએ કે આપણું સ્ટેક2 કાર્યલાઇન નંબર 3 માં ફંક્શન stack1 માં કૉલ કરવામાં આવ્યો હતો.
- ટોપમોસ્ટ પર જઈને, આપણે જોઈએ છીએ કે ફંક્શન સ્ટેક1 ને લાઇન નંબર 11 માં કૉલ કરવામાં આવ્યો હતો. મોડ્યુલ > અમને જણાવે છે કે તે ફાઇલ છે જે એક્ઝિક્યુટ કરવામાં આવી રહી છે.
સામાન્ય પાયથોન અપવાદો
પાયથોન લાઇબ્રેરી બિલ્ટ-ઇન અપવાદોની ભયાનક સંખ્યાને વ્યાખ્યાયિત કરે છે. તમે પાયથોન દસ્તાવેજીકરણ તપાસી શકો છો અથવા બિલ્ટ-ઇન સ્થાનિક () ફંક્શનને નીચે પ્રમાણે કૉલ કરી શકો છો:
>>> dir(locals()['__builtins__'])
અમે આ બધા અપવાદોને સંબોધવાનો પ્રયાસ કરીશું નહીં, પરંતુ અમે થોડા સામાન્ય અપવાદો જોશું. જે તમને સંભવ છે.
#1) TypeError
જ્યારે કોઈ અયોગ્ય પ્રકારના ઑબ્જેક્ટ પર ઑપરેશન અથવા ફંક્શન લાગુ કરવામાં આવે ત્યારે તે ઊભું થાય છે.
ઉદાહરણ 1
નીચેના પ્રોગ્રામને ધ્યાનમાં લો. તે ડિવિડન્ડ અને વિભાજક લે છે, પછી વિભાજક દ્વારા ડિવિડન્ડને વિભાજિત કરવાના પરિણામની ગણતરી અને પ્રિન્ટ કરે છે.
def compute_division(): dividend = int(input("Enter the dividend: ")) # cast string to int divisor = input("Enter the divisor: ") # no casting # Compute division result = dividend/divisor # print result print("The result of {}/{} is: {}".format(dividend, divisor, result)) if __name__ == '__main__': result = compute_division()
અમે વપરાશકર્તા પાસેથી ડિવિડન્ડ અને વિભાજકની કિંમતની વિનંતી કરીએ છીએ, પરંતુ અમે વિભાજકની સ્ટ્રિંગ નાખવાનું ભૂલી જઈએ છીએ. પૂર્ણાંકમાં મૂલ્ય. તેથી, આપણે ડિવિડન્ડનો પ્રકાર પૂર્ણાંક( int ) અને વિભાજકનો પ્રકાર શબ્દમાળા ( str ) સાથે સમાપ્ત થઈએ છીએ. પછી અમને TypeError મળે છે કારણ કે ડિવિઝન ઓપરેટર (/) સ્ટ્રીંગ્સ પર કામ કરતું નથી.
તમને એ જાણવામાં રસ હશે કે પાયથોનથી વિપરીત, જાવાસ્ક્રિપ્ટમાં પ્રકાર બળજબરી છે જે મૂળભૂત રીતે ઓપરેન્ડના પ્રકારોમાંથી એકને અન્ય ઓપરેન્ડના પ્રકારના સમકક્ષ મૂલ્યમાં રૂપાંતરિત કરે છે જ્યારે ઓપરેન્ડવિવિધ પ્રકારો.
#2) ValueError
જ્યારે કોઈ ઑપરેશન અથવા ફંક્શન એવી દલીલ પ્રાપ્ત કરે છે જેમાં યોગ્ય પ્રકાર હોય પરંતુ અયોગ્ય મૂલ્ય હોય ત્યારે આ વધારો થાય છે.
ઉદાહરણ 2
ઉપરના ઉદાહરણ 1 માં અમારા પ્રોગ્રામને ધ્યાનમાં લો.
જો વપરાશકર્તા '3a' જેવા ડિવિડન્ડ માટે આલ્ફાન્યૂમેરિક મૂલ્ય ઇનપુટ કરે છે, તો અમારો પ્રોગ્રામ વધશે ValueError અપવાદ. આનું કારણ એ છે કે, જોકે પાયથોન int() પદ્ધતિ કોઈપણ સંખ્યા અથવા સ્ટ્રિંગ લે છે અને પૂર્ણાંક ઑબ્જેક્ટ પરત કરે છે, સ્ટ્રિંગ મૂલ્યમાં અક્ષરો અથવા કોઈપણ બિન-સંખ્યાત્મક મૂલ્ય હોવું જોઈએ નહીં.
#3) એટ્રિબ્યુટ એરર
અસ્તિત્વમાં ન હોય તેવા એટ્રિબ્યુટને સોંપતી અથવા સંદર્ભિત કરતી વખતે આ અપવાદ ઉભો કરવામાં આવે છે.
ઉદાહરણ 3
પ્રોગ્રામને ધ્યાનમાં લો નીચે. તે સંખ્યા લે છે અને પાયથોન ગણિત મોડ્યુલનો ઉપયોગ કરીને તેના વર્ગમૂળની ગણતરી કરે છે
import math # import math library to gain access to its code def compute_square_root(number): # compute the square root using the math library result = math.sqr(number) return result if __name__ == '__main__': # get input to compute from user number = int(input("Compute Square root of: ")) # call function to compute square root
જ્યારે વપરાશકર્તા સંખ્યા દાખલ કરે છે, ત્યારે અમારો પ્રોગ્રામ તેના વર્ગમૂળની ગણતરી કરવા માટે ગણિત મોડ્યુલમાંથી ફંક્શનનો ઉપયોગ કરવાનો પ્રયાસ કરે છે પરંતુ અહીં તે જ છે, અમે ભૂલ કરી. sqrt ને બદલે, અમે ભૂલથી sqr ટાઈપ કર્યું છે જે ગણિત મોડ્યુલમાં અસ્તિત્વમાં નથી.
તેથી, અમે એક વિશેષતા sqr નો સંદર્ભ આપવાનો પ્રયાસ કરી રહ્યા હતા જે અસ્તિત્વમાં નથી અને અપવાદ એટ્રિબ્યુટ એરર ઊભી થઈ રહી છે. આપણામાંથી મોટા ભાગના લોકો આ પ્રકારની ભૂલ ઘણી વખત કરતા હોય છે. તેથી, તમે એકલા નથી.
અપવાદોને અજમાવીને હેન્ડલિંગ કરો
એક પ્રોગ્રામર તરીકે, એક વસ્તુ કે જેના પર આપણામાંથી મોટાભાગના લોકો અમારો સમય પસાર કરશે તે છે એક મજબૂત કોડ લખવો જે છેસ્થિતિસ્થાપક કોડ કે જે કેટલીક ભૂલોને કારણે તૂટતો નથી. પાયથોનમાં, અમે અમારા નિવેદનોને પ્રયાસ – સિવાય સ્ટેટમેન્ટની અંદર બંધ કરીને આ પ્રાપ્ત કરી શકીએ છીએ.
પાયથોન ટ્રાય-એક્સાઇડ સ્ટેટમેન્ટ
0>આ કોડને ચલાવવાથી આઉટપુટ આવશે
આ રીતે ટ્રાય-સિવાય સ્ટેટમેન્ટ કામ કરે છે. પાયથોન કોડને ટ્રાય બ્લોક લાઇન 7-8 માં ચલાવે છે. જો કોઈ અમાન્ય કોડ ન મળે, તો બ્લોક લાઈન 10 સિવાયનો કોડ છોડી દેવામાં આવે છે અને એક્ઝેક્યુશન ચાલુ રહે છે.
પરંતુ, જો કોઈ અમાન્ય કોડ મળે, તો અમલ તરત જ બંધ થઈ જાય છે. બ્લોક કરવાનો પ્રયાસ કરો અને ચકાસો કે અપવાદ એ અપવાદ વિધાન લાઇન 9 માં આપેલા અપવાદ સાથે મેળ ખાય છે કે કેમ. જો તે મેળ ખાય છે, તો સિવાય બ્લોક ચલાવવામાં આવે છે અને ચાલુ રહે છે. જો તે ન થાય, તો પ્રોગ્રામ વિક્ષેપ પાડશે.
ટ્રાય-બ્લોકમાં સામાન્ય રીતે કોડ હોય છે જે અપવાદને વધારી શકે છે જ્યારે સિવાય-બ્લોક અપવાદને પકડે છે અને હેન્ડલ કરે છે.
મલ્ટિપલ હેન્ડલિંગ અપવાદો સાથે અપવાદો
અમે એક "સિવાય" અથવા બહુવિધ "સિવાય" સાથે બહુવિધ અપવાદોને હેન્ડલ કરી શકીએ છીએ. તે બધું તમે દરેક અપવાદને કેવી રીતે હેન્ડલ કરવા માંગો છો તેના પર નિર્ભર કરે છે.
#1) એક સિવાય એક સાથે બહુવિધ અપવાદોને હેન્ડલ કરવું
try: #your code goes here except(Exception1[, Exception2[,...ExceptionN]]]): #handle exception here
આ પદ્ધતિનો ઉપયોગ જ્યારે અમને શંકા હોય કે અમારો કોડ હોઈ શકે છેજુદા જુદા અપવાદો ઉભા કરો અને અમે દરેક કેસમાં સમાન પગલાં લેવા માંગીએ છીએ. તેથી, જો પાયથોન ઈન્ટરપ્રીટર મેચ શોધે, તો બ્લોક સિવાયના ભાગમાં લખાયેલ કોડ એક્ઝિક્યુટ થશે.
ચાલો નીચે આપેલા પાયથોન કોડનું ઉદાહરણ ધ્યાનમાં લઈએ
def get_fraction(value, idx): arr = [4,5,2,0] # a list of numbers idx_value = arr[idx] # if idx is > arr length, IndexError will be raised value/idx_value # if idx_value == 0, ZeroDivisionError will be raised if __name__ =='__main__': # set 'value' and 'idx' value = 54 idx = 3 # call function in a try-except statement. try: result = get_fraction(value, idx) print("Fraction is ", result) except (IndexError, ZeroDivisionError) as ex: print(ex)
આપણી પાસે બે છે. સંભવિત અપવાદો કે જે અહીં ઉભા કરી શકાય છે, ZeroDivisionError અને IndexError . જો આમાંના કોઈપણ અપવાદો ઉભા કરવામાં આવે, તો અપવાદ સિવાયનો બ્લોક ચલાવવામાં આવશે.
ઉપરના કોડમાં, idx=3, તેથી idx_ મૂલ્ય 0 અને મૂલ્ય બને છે. /idx_ મૂલ્ય ZeroDivisionError વધારશે
#2) બહુવિધ અપવાદો સાથે બહુવિધ અપવાદોને હેન્ડલ કરવું
try: #your code goes here except Exception1: #handle exception1 here except Exception2: #handle exception2 here except ExceptionN: #handle exceptionN here
જો આપણે તેને હેન્ડલ કરવા ઈચ્છીએ તો દરેક અપવાદ અલગથી, પછી તમે આ રીતે કરી શકો છો.
નીચે આપેલા પાયથોન કોડના ઉદાહરણને ધ્યાનમાં લો
def get_fraction(value, idx): arr = [4,5,2,0] # a list of numbers idx_value = arr[idx] # if idx is > arr length, IndexError will be raised value/idx_value # if idx_value == 0, ZeroDivisionError will be raised if __name__ =='__main__': # set 'value' and 'idx' value = 54 idx = 5 # call function in a try-excepts statement. try: result = get_fraction(value, idx) print("Fraction is ", result) except IndexError: print("idx of {} is out of range".format(idx)) except ZeroDivisionError: print("arr[{}] is 0. Hence, can't divide by zero".format(idx)) except Exception as ex: print(ex) print("Not sure what happened so not safe to continue, \ app will be interrupted") raise ex
અમે અહીં નોંધ્યું છે કે અપવાદનો ઉપયોગ છેલ્લા સિવાયના નિવેદનમાં કરવામાં આવ્યો હતો. . આ એટલા માટે છે કારણ કે અપવાદ ઑબ્જેક્ટ અપવાદ કોઈપણ અપવાદ સાથે મેળ ખાય છે. આ કારણોસર, તે હંમેશા છેલ્લું હોવું જોઈએ, કારણ કે પાયથોન અન્ય અપવાદ હેન્ડલર્સને એક વખત મેચ થવા પર તપાસવાનું બંધ કરશે.
ઉપરના કોડમાં, idx=5 , તેથી arr[idx ] વધારો કરશે IndexError કારણ કે idx સૂચિની લંબાઈ કરતાં વધુ છે arr
આ ઉપરાંત, ખાતરી નથી કે તમારી અરજી દ્વારા કયો અપવાદ ઉઠાવવામાં આવ્યો છે તે અમલ ચાલુ રાખવા માટે ક્યારેય સલામત નથી. તેથી જ અમારી પાસે કોઈપણ અણધાર્યા અપવાદોને પકડવા માટે અપવાદ પ્રકાર છે. પછી, અમે જાણ કરીએ છીએવપરાશકર્તા અને સમાન અપવાદને વધારીને એપ્લિકેશનને અવરોધે છે.
અન્ય નિવેદનનો પ્રયાસ કરો
આ અપવાદ સંભાળવાની વૈકલ્પિક સુવિધા છે અને તમને કોડ ઉમેરવાની મંજૂરી આપે છે જે તમે ઇચ્છો છો જ્યારે કોઈ ભૂલ ન થાય ત્યારે ચલાવો. જો કોઈ ભૂલ થાય, તો આ અન્ય-બ્લોક ચાલશે નહીં.
નીચે આપેલા પાયથોન કોડનું ઉદાહરણ ધ્યાનમાં લો, તમારું એડિટર ખોલો અને કોડને elseTry.py
def fraction_of_one(divisor): value = 1/divisor # if divisor is zero, ZeroDivisionError will be raised return value if __name__ == '__main__': while True: try: # Get input from the user. # if input is not a valid argument for int(), ValueError will be raised divisor = int(input("Enter a divisor: ")) # call our function to compute the fraction value = fraction_of_one(divisor) except (ValueError, ZeroDivisionError): print("Input can't be zero and should be a valid literal for int(). Please, try again!") else: print("Value: ", value) break0 તરીકે સાચવો>અમે વપરાશકર્તા પાસેથી ઇનપુટ મેળવીએ છીએ અને તેનો ઉપયોગ 1 ને વિભાજીત કરવા માટે કરીએ છીએ. અમારી પાસે અહીં બે સંભવિત અપવાદો છે, એક અમાન્ય વપરાશકર્તા ઇનપુટ જે ValueErrorઅને zero(0)નું કારણ બનશે. ઝીરો ડિવિઝન એરર. અમારું સિવાયનું સ્ટેટમેન્ટ આ ભૂલોને સંભાળે છે.
હવે, અમે મૂલ્ય ની કિંમત છાપવા માંગીએ છીએ. અમારું અન્ય-બ્લોક ખાતરી કરે છે કે તે ફક્ત ત્યારે જ છાપવામાં આવે છે જો અમારો પ્રયાસ બ્લોક ભૂલ વિના એક્ઝિક્યુટ થાય. આ મહત્વપૂર્ણ છે કારણ કે જો અમારા ટ્રાય-બ્લોકમાં કોઈ ભૂલ થાય છે, તો મૂલ્ય અવ્યાખ્યાયિત રહેશે. તેથી, તેને ઍક્સેસ કરવાથી બીજી ભૂલ થશે.
ઉપરનો કોડ Python elseTry.py
ઉપરનો આઉટપુટ બતાવે છે કે પ્રથમ ઇનપુટ માટે, અમે 0 ટાઇપ કર્યું અને ENTER દબાવ્યું. અમારા વિભાજકે 0 મેળવ્યા હોવાથી, 1/વિભાજકે zeroDivisionError ઉભા કર્યા. અમારું બીજું ઇનપુટ k હતું જે int () માટે અમાન્ય છે, તેથી અપવાદ ValueError ઊભો થયો છે.
પરંતુ અમારું છેલ્લું ઇનપુટ 9 હતું જે માન્ય છે અને એક તરીકે પરિણામ, અમને 0.111111111111111
છેલ્લે અજમાવી જુઓવિધાન
આ અપવાદ હેન્ડલિંગની વૈકલ્પિક સુવિધા પણ છે અને અપવાદ હેન્ડલર્સમાં ગમે તે થાય તે હંમેશા ચાલશે.
તે છે:
- અપવાદ થાય કે ન થાય
- અન્ય બ્લોક્સમાં 'રીટર્ન' બોલાવવામાં આવે તો પણ.
- અન્ય બ્લોક્સમાં સ્ક્રિપ્ટ બહાર નીકળી ગઈ હોય તો પણ
તેથી, જો અમારી પાસે કોડ હોય કે જે અમે તમામ પરિસ્થિતિઓમાં ચલાવવા માંગીએ છીએ, તો આખરે-બ્લોક એ અમારો વ્યક્તિ છે. આ બ્લોકનો ઉપયોગ મોટાભાગે ફાઈલોને બંધ કરવા જેવા ક્લીન-અપ માટે થાય છે.
નીચે આપેલા પાયથોન કોડનું ઉદાહરણ ધ્યાનમાં લો
def readFile(file_path): try: openFile = open(file_path,'r') # Open a file as read-only print(openFile.readline()) # Read first line of file content except FileNotFoundError as ex: print(ex) finally: print("Cleaning...") openFile.close() if __name__ == '__main__': filePath = './text.txt' readFile(filePath)
આ કોડ ટેક્સ્ટ.txt ફાઇલને ખોલવાનો અને વાંચવાનો પ્રયાસ કરે છે. તેની વર્તમાન ડિરેક્ટરીમાં. જો ફાઈલ અસ્તિત્વમાં છે, તો આપણો પ્રોગ્રામ ફાઈલની પ્રથમ લીટીને પ્રિન્ટ કરશે પછી આપણો ફાઈલ-બ્લોક રન કરશે અને ફાઈલ બંધ કરશે.
કહો કે આપણી પાસે ડિરેક્ટરીમાં text.txt નામની ફાઈલ છે જ્યાં આ પ્રોગ્રામ ફાઈલ છે. હેલો છે અને સમાવે છે. જો આપણે પ્રોગ્રામ ચલાવીશું, તો આપણી પાસે આઉટપુટ હશે
આ ઉદાહરણ ઇરાદાપૂર્વક પસંદ કરવામાં આવ્યું હતું કારણ કે હું ઇચ્છું છું કે અમે એક નાની સમસ્યાનું નિરાકરણ કરીએ જે ફાઈલ બંધ કરતી વખતે આવી શકે છે- બ્લોક.
જો ફાઈલ અસ્તિત્વમાં નથી, તો અપવાદ FileNotFoundError ઊભો કરવામાં આવશે અને ચલ openFile વ્યાખ્યાયિત કરવામાં આવશે નહીં અને તે ફાઇલ હશે નહીં. પદાર્થ આથી, તેને ફાઈનલી-બ્લોકમાં બંધ કરવાનો પ્રયાસ અપવાદ UnboundLocalError ઉભો કરશે જે NameError નો સબક્લાસ છે.
આ મૂળભૂત રીતે કહે છે કે અમે સંદર્ભ આપવાનો પ્રયાસ કરી રહ્યા છીએ. આ