Python Try Except - мысалдары бар Python өңдеу ерекше жағдай

Бұл оқулық бағдарламалау мысалдарының көмегімен Try Except блогын пайдаланып Python тілінде Ерекшеліктерді өңдеуді түсіндіреді:

Қатенің екі түрі Python бағдарламасының кенет тоқтап қалуына әкелуі мүмкін, яғни Синтаксис Қателер және Ерекшеліктер . Бұл оқулықта біз бірнеше маңызды тақырыптар бойынша екінші қате түрін (Ерекшеліктер) талқылайтын боламыз.

Біз қолданбамыздағы ерекше жағдайларды өңдеуден көп пайда аламыз, мысалы:

  • Мықты қолданба жасау.
  • Таза және қатесіз код жасау.

Python Try Except

Бір жақсы жаңалық - Python-да кодымыздағы қателерді анықтау үшін кірістірілген ерекше жағдайлардың жақсы саны бар. Сондай-ақ, ол кірістірілген ерекшеліктердің ешқайсысы біздің қажеттіліктерімізге сәйкес келмесе, реттелетін ерекше жағдайларды жасауға мүмкіндік береді.

Ерекшелік дегеніміз не

Сонымен Python-да ерекшелік дегеніміз не? Қарапайым тілмен айтқанда, Python интерпретаторы жарамсыз кодты орындауға тырысқанда, ол ерекше жағдайды тудырады және мұндай ерекшелік өңделмеген жағдайларда, ол бағдарлама нұсқауларының қалыпты ағынын бұзады және кері бақылауды басып шығарады.

Жарамсыз код жасап, Python аудармашысының қалай жауап беретінін көрейік.

Python қабықшасын ашып, келесі кодты іске қосыңыз.

>>> 50/0

Бұл кодтардың бірі бағдарламалауда жиі кездесетін қателер. Жоғарыдағы код 50 санын 0 (нөл)-ге бөлуге тырысады. Pythonайнымалы openFile ол тағайындалғанға дейін.

Бұл жерде шағын трюк - finally-блок ішінде ерекше жағдай өңдегіштерін пайдалану.

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 мәнін көтерсе, онда біз келесі нәтижеге ие боламыз

Ерекше жағдайды көтеру

Python ерекше жағдайлары туралы жақсы жаңалық - біз әдейі жасай аламыз. оларды өсіру. Ерекшеліктер raise операторы арқылы көтеріледі.

Көтеру мәлімдемесінде келесі синтаксис бар:

raise [ExceptionName[(*args: Object)]]

Терминалды ашыңыз және кез келген ерекшелік нысанын келесіден көтеріңіз. Python кірістірілген Ерекшеліктер. Мысалы, егер біз ZeroDivisionError-ды көтерсек:

>>> raise ZeroDivisionError("Can't divide by zero")

Біз кері қайтаруды аламыз:

Сонымен, Ерекшеліктерді көтеру неліктен маңызды?

  • Теңшелетін ерекше жағдайлармен жұмыс істегенде.
  • Сананы тексеру кезінде.

Арнайы ерекшелік сыныптары

Таңдамалы ерекшелік - бұл сіздің қажеттіліктеріңізге сәйкес қателерді өңдеу үшін жасайтын ерекше жағдай. Мәселе мынада, біз Ерекше нысанынан шығатын классты анықтаймыз, содан кейін біз ерекше жағдай сыныбын көтеру үшін rise операторын қолданамыз.

Пайдаланушы енгізуін тексеріп, көз жеткізгіміз келеді делік. кіріс мәні теріс емес (санитет тексеру). Әрине, біз Python ValueError ерекше жағдайын көтере аламыз, бірақ біз оған InputIsNegativeError сияқты нақты және өзін-өзі түсіндіретін атау беру арқылы қатені теңшегіміз келеді. Бірақ бұл ерекшелік орнатылған Python емесЕрекше жағдай.

Осылайша, алдымен Ерекшеліктен алынатын базалық классты жасаймыз.

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") 

Пайдаланушы енгізуіне арналған жоғарыдағы код сұрауын және оның теріс екенін тексеріңіз. Егер шын болса, ол кейін istisna мәлімдемесінде ұсталатын 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-сұрақ) Python ерекше жағдайды қалай өңдейді?

Жауап: Python ерекше жағдайларды көмегімен өңдейді. try-except операторы . Ерекше жағдайды тудыруы мүмкін код сынау блогында орналастырылады және орындалады, ал блоктан басқа кез келген пайда болған жағдайда ерекшеліктерді өңдейтін кодты ұстайды.

2-сұрақ) Python-да ерекше жағдайды көтеру дегеніміз не?

Жауап: Python аудармашысы жарамсыз кодқа кезіккенде, ол ерекше жағдайды тудырады, бұл Python-ның өзіндік тәсілі. бізге күтпеген нәрсе болғанын айту. Біз сондай-ақ raise операторы арқылы ерекшеліктерді әдейі көтере аламыз.

С №3) Python бірнеше ерекшеліктерді қалай өңдейді?

Жауап: Python бірнеше ерекшеліктерді өңдейдібір блоктан басқа немесе блоктардан басқа бірнеше блокты пайдалану.

Бір блок үшін ерекшеліктер кортеж ретінде беріледі: басқа (Ерекше 1, Ерекшелік2,.., ЕрекшелікN) және Python тексерулері матч үшін оңнан солға қарай. Бұл жағдайда әрбір ерекше жағдай үшін бірдей әрекет орындалады.

Барлық ерекшеліктерді ұстаудың тағы бір жолы - except кілт сөзінен кейін ерекше жағдайдың атын қалдыру.

except: # handle all exceptions here

Екінші әдіс - әрбір ерекше жағдай үшін istisna блогын пайдалану үшін:

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-сұрақ) Ерекшеліктерді өңдеу Python-да неліктен маңызды?

Жауап: Python-да ерекше жағдайларды өңдеудің артықшылығы - біз сенімді, таза және қатесіз қолданбаларды жасай аламыз. Кейбір қателерге байланысты өндіріс кодының бұзылғанын қаламаймыз, сондықтан біз қателерді өңдейміз және қолданбамызды жұмыс істеп тұрамыз.

С №5) Python-да ерекше жағдайды қалай елемеді?

Жауап: Python-да ерекше жағдайды елемеу үшін, except блогында pass кілт сөзін пайдаланыңыз. ValueError ерекшелігін елемейміз делік. Біз мұны осылай жасаймыз:

except ValueError: pass

Не істеп жатқаныңызды білмейінше, ерекше жағдайларды елемеу жаман тәжірибе. Кем дегенде, пайдаланушыны барлық ықтимал қателер туралы хабардар етіңіз.

Қорытынды

Бұл оқулықта біз мыналарды қарастырдық: Python ерекшеліктері, Traceback; Три / Басқа / Басқа / Соңында арқылы ерекшеліктерді өңдеу әдісіблоктар, Жоғары Ерекшеліктерді қалай жасауға болады және ең соңында жеке Ерекшеліктерімізді қалай жасауға болады.

Оқығаныңыз үшін рақмет!

аудармашы мұны жарамсыз әрекет ретінде көреді және ZeroDivisionErrorшығарады, бағдарламаны бұзады және кері бақылауды басып шығарады.

Біз екенін анық көреміз. ZeroDivisionError - көтерілген ерекше жағдай. Бұл санды нөлге бөлу жақсы емес екенін айтудың Python-ның өзіндік тәсілі. JavaScript сияқты басқа тілдерде бұл қате емес; және python бұл тәжірибеге қатаң тыйым салады.

Сонымен қатар, бұл тек ерекшелік нысаны екенін және Python-да мұндай нысандардың көптеп орнатылғанын білу маңызды. Барлық Python кірістірілген ерекшеліктерін көру үшін осы Python ресми құжаттамасын қараңыз.

Бақылауды түсіну

Ерекше жағдайларды өңдеуге кіріспес бұрын, бұл ерекше жағдайлар болған жағдайда нақты не болатынын түсінуге көмектеседі деп ойлаймын. өңделмейді және Python біздің қате туралы бізге хабарлау үшін қолдан келгеннің бәрін жасайды.

Python қатеге кезіккенде, ол ерекше жағдайды тудырады. Бұл ерекшелік өңделмесе, ол Traceback деп аталатын кейбір ақпаратты шығарады. Сонымен, бұл кері бақылау қандай ақпаратты қамтиды?

Ол мыналарды қамтиды:

  • Қандай ерекшелік туындағанын және осы ерекшелік болғанға дейін не болғанын көрсететін қате туралы хабар. көтерілді.
  • Осы қатені тудырған кодтың әртүрлі жол нөмірлері. Қате шақыру стегі деп аталатын функциялық шақырулар тізбегінен туындауы мүмкін, оны кейінірек осы жерде талқылаймыз.

Бірақ бұлаздап шатастыратын болсақ, келесі мысал біздің түсінігімізге көбірек нұр әкеледі деп уәде береміз.

Жоғарыда 50-ні 0-ге бөлу арқылы басып шығарылған кері бақылауды еске түсіріңіз, біз бақылауда келесі ақпаратты қамтитынын көреміз:

  • Файл “”: Бұл кодтың консоль терминалынан іске қосылғанын көрсетеді.
  • 1-жол: Бұл жол нөмірінде қате орын алғанын көрсетеді.
  • ZeroDivisionError: нөлге бөлу: Ол бізге қандай ерекшелік туындағанын және оған не себеп болғанын айтады.

Басқа мысалды қолданып көрейік және қоңыраулар стегі қалай көрінетінін көруіңіз мүмкін. Редакторды ашыңыз, төмендегі кодты енгізіңіз және 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

Келесі кері қайтаруды көресіз:

Жоғарыдағы кері қайтару түсініксіз болып көрінуі мүмкін, бірақ олай емес. Pythonistas төменнен жоғарыға болатын бақылауды оқудың ең жақсы әдісін ойлап тапты. Ендеше, осы бақылаудың не ұсынатынын түсіну үшін осы даналықты қолданайық.

  • Төменгі жағында біз көтерілген ерекше жағдайды және оның неге көтерілгенін аламыз.
  • Жоғары жылжытқанда, біз осы қате орын алған tracebackExp .py файл атауын, осы қатені тудырған есептеуді есептеу = numb/div, stack2 функциясын және осы есептеу орындалған 6 сілтеме нөмірін аламыз. .
  • Жоғары жылжып, біз стек2 жұмыс істейтінін көреміз№3 жолдағы стек1 функциясына шақырылды.
  • Ең жоғарғыға жылжып, 11-жолда steck1 функциясы шақырылғанын көреміз. модуль > орындалып жатқан файл екенін айтады.

Жалпы Python Ерекшеліктері

Python кітапханасы кірістірілген ерекшеліктердің өте көп бөлігін анықтайды. Python құжаттамасын тексеруге немесе кірістірілген local () функциясын төмендегідей шақыруға болады:

>>> 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 аламыз, себебі бөлу операторы (/) жолдарда жұмыс істемейді.

Python-дан айырмашылығы, бұл сізді қызықтыруы мүмкін. Javascript-те операнд түрлерінің бірін операндтар басқа операнд түрінің эквивалентті мәніне түрлендіретін Type Coercion бар.әр түрлі типтер.

#2) ValueError

Бұл операция немесе функция дұрыс түрі, бірақ сәйкес емес мәні бар аргумент алған кезде көтеріледі.

Мысалы 2

Жоғарыдағы 1-мысал -дегі бағдарламамызды қарастырыңыз.

Егер пайдаланушы дивиденд үшін '3a' сияқты әріптік-сандық мән енгізсе, біздің бағдарламамыз көтеріледі. ValueError ерекшелігі. Себебі, Python int() әдісі кез келген санды немесе жолды қабылдап, бүтін нысанды қайтарса да, жол мәнінде әріптер немесе сандық емес мән болмауы керек.

#3) AttributeError

Бұл ерекшелік жоқ төлсипатты тағайындау немесе оған сілтеме жасау кезінде көтеріледі.

3-мысал

Бағдарламаны қарастырыңыз төменде. Ол санды қабылдайды және Python математикалық модулінің көмегімен шаршы түбірін есептейді

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 атрибутына сілтеме жасауға тырыстық. ерекше жағдайға AttributeError көтеріледі. Көбіміз мұндай қатені жиі жібереміз. Сонымен, сіз жалғыз емессіз.

Тренинг арқылы ерекше жағдайларды өңдеу

Бағдарламашы ретінде көпшілігіміз уақытымызды жұмсайтын нәрсенің бірі - сенімді код жазу.төзімді. Кейбір қателерге байланысты бұзылмайтын код. Python-да біз бұған мәлімдемелерімізді try except операторының ішіне қосу арқылы қол жеткізе аламыз.

Python Try-Except операторы

try-except операторының келесі құрылымы бар:

try: #your code goes here except """Specify exception type(s) here""": #handle exception here 

Кодты tracebackExp .py ішіне try-except операторының ішіне енгізейік.

def stack1(numb): # 1 div = 0 # 2 stack2(numb, div) # 3 def stack2(numb, div): # 5 try: # 6 compute = numb/div # 7 print(compute) # 8 except ZeroDivisionError as zde: # 9 print(zde) # 10 if __name__ == '__main__': # 12 numb = 5 # 13 stack1(numb) # 14 print("program continuous") # 15 

Осы кодты іске қосу нәтижені береді

try-except операторы осылай жұмыс істейді. Python кодты 7-8-жолы сынақ блогында орындайды. Егер жарамсыз код табылмаса, 10-жол қоспағанда блоктағы код өткізіп жіберіледі және орындау жалғасады.

Бірақ жарамсыз код табылса, онда орындау дереу тоқтатылады. try block және шығарылған ерекше жағдайдың 9-жолда except операторында берілгенге сәйкес келетінін тексереді. Егер ол сәйкес келсе, онда except блогы орындалады және жалғасады. Егер олай болмаса, онда бағдарлама үзіледі.

Әдетте try-block ерекше жағдайды тудыруы мүмкін кодты қамтиды, ал except-блок ерекше жағдайды ұстайды және өңдейді.

Бірнеше әрекетті өңдеу Ерекшеліктер

қоспағанда, біз бір "басқа" немесе бірнеше "басқалар" арқылы бірнеше ерекшеліктерді өңдей аламыз. Мұның бәрі әрбір ерекше жағдайды қалай өңдегіңіз келетініне байланысты.

№1) Бірнеше ерекшеліктерді жалғызымен өңдеу

try: #your code goes here except(Exception1[, Exception2[,...ExceptionN]]]): #handle exception here 

Бұл әдіс біздің кодымыз мүмкін деп күдіктенген кезде қолданылады.әртүрлі ерекшеліктерді көтеріңіз және біз әр жағдайда бірдей әрекетті қолданғымыз келеді. Сонымен, егер Python интерпретаторы сәйкестікті тапса, онда except блогында жазылған код орындалады.

Төмендегі Python кодының мысалын қарастырайық

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 . Егер осы ерекшеліктердің кез келгені көтерілсе, istisna блогы орындалады.

Жоғарыдағы кодта 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 

Егер біз өңдегіміз келсе әрбір ерекшелік бөлек болса, оны осылай жасауға болады.

Төмендегі Python кодының мысалын қарастырыңыз

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 

Бұл жерде Exception соңғы except операторында қолданылғанын байқаймыз. . Себебі Exception ерекшелік нысаны кез келген ерекшелікке сәйкес келеді. Осы себепті ол әрқашан соңғы болуы керек, өйткені Python басқа ерекшелік өңдеушілерінің бірі сәйкес келген кезде тексеруді тоқтатады.

Жоғарыдағы кодта idx=5 , демек arr[idx ] IndexError көтереді, себебі idx тізімнің ұзындығынан үлкен arr

Сонымен қатар, қолданбаңыздың қандай ерекшелік туғызғанын білмеу, орындауды жалғастыру үшін ешқашан қауіпсіз емес. Сондықтан кез келген күтпеген ерекшеліктерді ұстау үшін бізде Exception түрі бар. Сосын хабарлаймызпайдаланушыға және бірдей ерекше жағдайды көтеру арқылы қолданбаны үзіңіз.

Else мәлімдемесін көріңіз

Бұл ерекше жағдайды өңдеудің қосымша мүмкіндігі және сізге қажет кодты қосуға мүмкіндік береді. қателер болмаған кезде іске қосыңыз. Қате орын алса, бұл else-блок іске қосылмайды.

Төмендегі Python кодының мысалын қарастырыңыз, өңдегішті ашыңыз және кодты 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) break 
0 ретінде сақтаңыз>Біз пайдаланушыдан енгізуді аламыз және оны 1-ге бөлу үшін пайдаланамыз. Бұл жерде бізде екі ықтимал ерекшелік бар, жарамсыз пайдаланушы енгізуі ValueErrorжәне нөл(0)туғызады. ZeroDivisionError. Біздің except операторымыз бұл қателерді өңдейді.

Енді біз мән мәнін басып шығарғымыз келеді. Біздің else-блок біздің try блок қатесіз орындалған жағдайда ғана оның басып шығарылғанына көз жеткізеді. Бұл өте маңызды, өйткені егер сынақ блогында қате орын алса, мән анықталмаған болады. Демек, оған қол жеткізу басқа қатені тудырады.

Жоғарыдағы кодты Python elseTry.py арқылы іске қосыңыз

Жоғарыдағы нәтиже мынаны көрсетеді бірінші енгізу үшін 0 теріп, ENTER пернесін басамыз. Біздің бөлгішіміз 0-ді алғандықтан, 1/бөлгіш нөлді бөлу қатесі көтерді. Біздің екінші енгізуіміз k болды, ол int () үшін жарамсыз, сондықтан ValueError ерекше жағдай көтерілді.

Бірақ біздің соңғы енгізуіміз 9 болды, ол жарамды және нәтиже, біз 0,1111111111111111 ретінде басып шығарылған “ мән ” мәнін алдық

Соңында көріңізМәлімдеме

Бұл сонымен қатар ерекше жағдайларды өңдеудің қосымша мүмкіндігі және ерекше жағдайларды өңдеушілерде не болғанына қарамастан әрқашан іске қосылады.

Яғни:

  • Ерекшелік орын ала ма, жоқ па
  • Тіпті басқа блоктарда «қайтару» шақырылса да.
  • Тіпті сценарий басқа блоктарда шықса да

Сонымен, егер бізде барлық жағдайда іске қосқымыз келетін код болса, ақырында-блок - бұл біздің жігіт. Бұл блок негізінен файлдарды жабу сияқты тазалау үшін пайдаланылады.

Төмендегі мысалды қарастырыңыз Python кодын

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) 

Бұл код text.txt файлын ашуға және оқуға тырысады. оның ағымдағы каталогында. Егер файл бар болса, біздің бағдарлама файлдың бірінші жолын басып шығарады, содан кейін соңғы блок іске қосылады және файлды жабады.

Осы бағдарлама файлы орналасқан каталогта text.txt деп аталатын файл бар делік. болып табылады және құрамында Hello. Егер біз бағдарламаны іске қосатын болсақ, бізде нәтиже болады

Бұл мысал әдейі таңдалды, себебі мен соңғы файлдағы файлдарды жабу кезінде туындауы мүмкін шағын мәселені шешуді қаладым. блок.

Егер файл жоқ болса, FileNotFoundError ерекше жағдай көтеріледі және openFile айнымалысы анықталмайды және файл болмайды. объект. Демек, оны finally-блокта жабу әрекеті NameError қосалқы сыныбы болып табылатын UnboundLocalError ерекше жағдайды тудырады.

Бұл негізінен сілтеме жасауға тырысып жатқанымызды білдіреді. the

Жоғарыға айналу