Archy
Исключения - это извещения интерпретатора, возбуждаемые в случае возникновения ошибок в программном коде или при наступлении какого-либо события. Если в коде не предусмотрена обработка исключения, то программа прерывается и выводит сообщение об ошибке.
Существует три типа ошибок в программе:
Синтаксические - это ошибка в имени оператора или функции, отсутствие закрывающей или открывающей кавычек и т.д., т.е. ошибки в синтаксисе языка. Как правило, интерпретатор предупредит о наличии ошибки, а программа не будет выполняться совсем. Пример синтаксической ошибки.
>>> print "Нет завершающей кавычки!
SyntaxError: EOL while scanning string literal
Логические - это ошибка в логике работы программы, которые можно выявить только по результатам работы скрипта. Как правило, интерпретатор не предупреждает о наличии ошибки. А программа будет выполняться, т.к. не содержит синтаксических ошибок. Такие ошибки достаточно трудно выявить и исправить.
Классы нового стиля позволяют создать идентификатор, через который можно получить, изменить или удалить значение атрибута класса. Создается такой идентификатор с помощью функции property(), форма функции:
<Свойства> = property(<Чтение>[, <Запись>[, <Удаление>[, <Строка документирования>]]])
В первых трех параметрах указывается ссылка на соответствующий метод класса. При попытке получить значение будет вызван метод, указанный в первом параметре. При операции присваивания значения будет вызван метод, указанный во втором параметре. Этот метод должен принимать один параметр. В случае удаления атрибута вызывается метод, указанный в третьем параметре. Если в качестве какого-либо параметра задано значение None, то это означает, что соответствующий метод не поддерживается. Рассмотрим свойства класса на примере.
Ограничение доступа к идентификаторам внутри класса
Все идентификаторы внутри класса в языке Python являются открытыми, т.е. доступы для непосредственного изменения. Для имитации частных идентификаторов можно воспользоваться методами __getattr__(), __getattribute__() и __setattr__(), которые перехватывают обращения к атрибутам класса. Кроме того, можно воспользоваться идентификаторами, названия которых начинаются с двух символов подчеркивания. Такие идентификаторы называются псевдочастными. Псевдочастные идентификаторы доступны внутри класса, но не доступны по имени через экземпляр класса.
Тем не менее, изменить идентификатор через экземпляр класса все равно можно, зная, каким образом искажается название идентификатора. Например, идентификатор __privateVar внутри класса Class1 будет доступен по имени _Class1__privateVar. Как видно из примера, перед идентификатором добавляется название класса с предваряющим символом подчеркивания. Приведем пример использования псевдочастных идентификаторов.
Абстрактные методы содержат только определение метода без реализации. Предполагается, что класс-потомок должен переопределить метод и реализовать его функциональность. Чтобы такое предположение сделать более очевидным, часто внутри абстрактного метода возбуждают исключение.
Абстрактные методы
class Class1(object):
def test(self, x): # Абстрактный метод
# Возбуждаем исключение с помощью raise
raise NotImplementedError("Необходимо переопределить метод")
class Class2(Class1): # Наследуем абстрактный метод
def test(self, x): # Переопределяем метод
print x
class Class3(Class1): # Класс не переопределяет метод
pass
c2 = Class2()
c2.test(50) # Выведет: 50
c3 = Class3()
try: # Перехватываем исключения
c3.test(50) # Ошибка. Метод test() не переопределен
except NotImplementedError, msg:
print msg # Выведет: Необходимо переопределить метод
Далее...
Внутри класса можно создать метод, который будет доступен без создания экземпляра класса. Для этого перед определением метода внутри класса следует указать декоратор @staticmethod. Вызов статического метода без создания экземпляра класса осуществляется следующим образом:
<Название класса>.<Название метода>(<Параметры>)Кроме того, можно вызвать статический метод через экземпляр класса:
<Экземпляр класса>.<Название метода>(<Параметры>)Пример использования статических методов вриведен ниже.
class Class1(object):
@staticmethod
def sum1(x, y): # Статический метод
return x + y
def sum2(self, x, y): # Обычный метод в классе
return x + y
def sum3(self, x, y):
return Class1.sum1(x, y) # Вызов из метода класса
print Class1.sum1(10, 20) # Вызываем статический метод
c1 = Class1()
print c1.sum2(15, 6) # Вызываем метод класса
print c1.sum1(50, 12) # Вызываем статический метод
# через экземпляр класса
print c1.sum3(23, 5) # Вызываем статический метод
# внутри класса
Далее...
Начиная с Python 2.2, помимо классических классов существует классы так называемого нового стиля. Классом нового стиля называется класс, у которого базовым классом является встроенный объект (например, list или dict) или объект object. Для классов старого и нового стили отличаются результатом выполнения функции type(), а также вывод атрибутов __class__ и __bases__ для экземпляров классов.
Классы нового стиля
class Class1: # Классический класс
pass
class Class2(object): # Класс нового стиля
pass
class Class3(list): # Класс нового стиля
pass
print type(Class1) # Выведет:
print type(Class2) # Выведет:
print type(Class3) # Выведет:
# __bases__ содержит кортеж с базовыми классами
print Class1.__bases__ # Выведет: ()
print Class2.__bases__ # Выведет: (,)
print Class3.__bases__ # Выведет: (,)
c1, c2, c3 = Class1(), Class2(), Class3()
print c1.__class__ # Выведет: __main__.Class1
print c2.__class__ # Выведет:
print c3.__class__ # Выведет:
print type(c1) # Выведет:
print type(c2) # Выведет:
print type(c3) # Выведет:
Далее...
В определенных классах в круглых скобках можно указать сразу несколько базовых классов через запятую. В этом случае поиск идентификаторов производится вначале в производном классе, затем в базовом классе, расположенном первым в списке, далее просматриваются все базовые классы базового класса. Только после этого просматривается базовый класс, расположенный в списке правее, и все его базовые классы. Список базовых классов просматривается слева направо. Результатом поиска будет первый найденный идентификатор. Рассмотрим множественное наследование на примере.
Множественное наследование
class Class1: # Базовый класс для класса Class2
def f_func1(self):
print "Метод f_func1() класса Class1"
class Class2(Class1): # Класс Class2 наследует класс Class1
def f_func2(self):
print "Метод f_func2() класса Class2"
class Class3(Class1): # Класс Class3 наследует класс Class1
def f_func1(self):
print "Метод f_func1() класса Class3"
def f_func2(self):
print "Метод f_func2() класса Class3"
def f_func3(self):
print "Метод f_func3() класса Class3"
def f_func4(self):
print "Метод f_func4() класса Class3"
class Class4(Class2, Class3): # Множественное наследование
def f_func4(self):
print "Метод f_func4() класса Class4"
c1 = Class4() # Создаем экземпляр класса Class4
c1.f_func1() # Выведет: Метод f_func1() класса Class1
c1.f_func2() # Выведет: Метод f_func2() класса Class2
c1.f_func3() # Выведет: Метод f_func3() класса Class3
c1.f_func4() # Выведет: Метод f_func4() класса Class4
Далее...
Наследование в Python является важным фактором для понимания принципа работы ООП. Предположим, у вас есть класс (Пример Class1). При помощи наследования мы можем создать новый класс (Например Class2), в котором будет доступ ко всем атрибутам и методам класса Class1, а также к некоторым атрибутам и методам.
Наследование
# -*- coding: utf-8 -*-
class Class1: # Базовый класс
def f_func1(self):
print "Метод f_func1() класса Class1"
def f_func2(self):
print "Метод f_func2() класса Class1"
class Class2(Class1): # Класс Class2 наследует класс Class1
def f_func3(self):
print "Метод f_func3() класса Class2"
c1 = Class2() # Создаем экземпляр класса Class2
c1.f_func1() # Выведет: Метод f_func1() класса Class1
c1.f_func2() # Выведет: Метод f_func2() класса Class1
c1.f_func3() # Выведет: Метод f_func3() класса Class2
Как видно из примера, класс Class1 указывается внутри круглых скобок в определение класса Class2. Таким образом, класс Class2 наследует все атрибуты и методы класса Class1. Класс Class1 вызывется базовым классом ими суперклассом, а класс Class2 - производным классом или подклассом.
При создании экземпляра класса интерпретатор автоматически вызывает метод инициализации __init__(). В некоторых языках программирования данные методы принято называть конструктором и деструктором класса. В языке программирования PHP это будет __construct(); __destruct(). Формат метода:
def __init__(self[, <Значение1>[, <ЗначениеN>]]):
<Выражение>
С помощью метода __init__() можно присвоить значения по умолчанию для атрибутах класса. При создании экземпляра класса начальные значения указываются после имени класса в круглых скобках:
<Экземпляр класса> = <Имя класса>(<Значение1>[, ..., <ЗначениеN>])
Пример использования метода __init__() приведен ниже:
# -*- coding: utf-8 -*-
class HexColor:
def __init__(self):
self.colors = {
'red' : '#ff0000',
'greed' : '#7cfc00',
'blue' : '#4169e1'
}
hex_color = HexColor()
print hex_color.colors['red'] # Получим: #ff0000
# Пример 2: Удваиваем число
class DoubleMe:
def __init__(self, number):
self.result = number * 2
Double = DoubleMe(2)
print Double.result # Получим 4
Далее...
Алгоритм расшифровки названии автомобилей в игре "Что за тачка?" на Python
Вчера знакомый в ВК дал мне запрос чтобы заправить его автомобиль, чтобы тот мог продолжить играть. Я не любитель онлайн игр из за быстрого привыкания к ним и стараюсь чтобы не зависать долго в них. Хотя, в какую игру бы не играл всегда ищу какой-то способ чтобы упростить для себя процесс и догнать всех по достижениям в ней. Автолюбителям понравится данная игра, но загвоздка в том, что популярные марки там редкость. Даже если и будет BMW или Mercedes-Benz то он напомнит вам фильмы из 60-х годов.
Игра становится все более популярной, уже созданы группы с фотографиями с просьбой о помощи угадать название машины. Если замедлить с ответом то очки выигрыша будут меньше и тогда не будет денег, чтобы купить топливо на следующий круг. Изначально некоторые машины я угадывал при помощи Google Images, там есть возможность дать ссылку на автомобиль и получить результаты поиска. Но, даже гугл иногда не знал, что это за тачка.
Алгоритм работы программы
- Искал в интернете список всех автомобильных марок и сохранил их в текстовой файл.
- Задавал число букв из которых состоит название автомобиля.
- Вписывал случайные буквы которые дает нам игра для подбора.
- Алгоритм сортирует названия марок и выводит результат.
Ссылка на расшифровку названии онлайн ТУТ!
Возникли вопросы по Python?
- Python для начинающих 71
- Python и запуск програм 16
- SQLite 12
- Веб-программирование 7
- Взаимодействие с Интернетом 401
- Видео уроки 7
- Запуск программ на Python 4
- Изучение PyQt5 12
- Изучение wxPython 1
- Модули 8
- Обработка исключений 3
- Общие вопросы 190
- ООП на Python 12
- Примеры Python 30
- Работа с изображениями 4
- Разработка интернет-приложений 8
- Как использовать proxy с помощью библиотеки Requests?
- Как работают функции в Python?
- Топ наиболее востребованных языков программирования
- Изучение языка программирования Python с помощью Brain Up!
- Распаковка последовательности в отдельные переменные
- Создание своего веб-фреймворка на Python - Часть 1
- Какая версия Python самая быстрая?