>1 | try:
>2 | a =float(input("Введите число: "))
>3 | except ValueError:
>4 | print ("Это не число!")
В данном примере программа пытается конвертировать информацию введенную пользователем в тип float, если же при этом возникнет ошибка класса ValueError, то выводится строка "This is not a valid number". В блоке except мы можем задать те классы ошибок на которые данный блок должен сработать, если мы не укажем ожидаемый класс ошибок, то блок будет реагировать на любую возникшую ошибку.
Блок try может содержать неограниченное количество блоков except:
>1 | try:
>2 | a =float(input ("Введите число: ")
>3 | print (100 / a)
>4 | except ValueError:
>5 | print ("Это не число")
>6 | except ZeroDivisionError:
>7 | print ("На ноль делить нельзя")
Кроме того мы можем добавить пустой блок except, который будет срабатывать на непредвиденную выше ошибку. Пустой блок except всегда должен идти последним:
>1 | try:
>2 | a =float(input ("Введите число: ")
>3 | print (100 / a)
>4 | except ValueError:
>5 | print ("Это не число")
>6 | except ZeroDivisionError:
>7 | print ("На ноль делить нельзя")
>8 | except:
>9 | print ("Неожиданная ошибка.")
Блоку except можно добавить необязательный блок else, который сработает в случае, если программа выполнилась без ошибок:
> 1 | try:
> 2 | a =float(input ("Введите число: ")
> 3 | print (100 / a)
> 4 | except ValueError:
> 5 | print ("Это не число")
> 6 | except ZeroDivisionError:
> 7 | print ("На ноль делить нельзя")
> 8 | except:
> 9 | print ("Неожиданная ошибка.")
>10 | else:
>11 | print ("Код выполнился без ошибок")
В результате, мы получим следующее.
Также у блока except есть еще один необязательный блок finally, который сработает независимо от того, выполнился код с ошибками или без:
> 1 | try:
> 2 | a =float(input ("Введите число: ")
> 3 | print (100 / a)
> 4 | except ValueError:
> 5 | print ("Это не число")
> 6 | except ZeroDivisionError:
> 7 | print ("На ноль делить нельзя")
> 8 | except:
> 9 | print ("Неожиданная ошибка.")
>10 | else:
>11 | print ("Код выполнился без ошибок")
>12 | finally:
>13 | print ("Я выполняюсь в любом случае!")
Таким образом, используя обработку исключительных ситуаций, вы можете защитить программу от взлома, непредвиденного поведения и в будущем получить детальную информацию по логическим ошибкам, содержащимся в ней.
HTML парсер на Python
Published: 08 April 2015
Учитывая современное развитие Интернета, было бы кощунством не написать приложение, взаимодействующее со всемирной паутиной. Сегодня мы напишем простенький html-парсер на Python. Наше приложение будет читать код указанной страницы сайта и сохранять все ссылки в ней в отдельный файл. Это приложение может помочь SEO-аналитикам и веб-разработчикам.
Писать будем на Python 3, в котором есть встроенный класс для html-парсера из модуля html.parser
>| from html.parser import HTMLParser
Так же нам понадобится функция urlopen из модуля urllib
>| from urllib.request import urlopen