MyTetra Share
Делитесь знаниями!
decorators / обертки
Время создания: 20.05.2017 21:35
Раздел: Python - decorators
Запись: xintrea/mytetra_db_mcold/master/base/1495305310st018x6sib/text.html на raw.githubusercontent.com
### 1. Декораторы / decorators как обертки


```python


def my_shiny_new_decorator(function_to_decorate):
#### Внутри себя декоратор определяет функцию-"обёртку". Она будет обёрнута вокруг декорируемой,
#### получая возможность исполнять произвольный код до и после неё.
def the_wrapper_around_the_original_function():
print("Я - код, который отработает до вызова функции")
function_to_decorate()
#### Сама функция
print("А я - код, срабатывающий после")

#### Вернём эту функцию
return the_wrapper_around_the_original_function


#### Представим теперь, что у нас есть функция, которую мы не планируем больше трогать.
def stand_alone_function():
print("Я простая одинокая функция, ты ведь не посмеешь меня изменять?")


stand_alone_function()
#### Однако, чтобы изменить её поведение, мы можем декорировать её, то есть просто передать декоратору,
#### который обернет исходную функцию в любой код, который нам потребуется, и вернёт новую,
#### готовую к использованию функцию:
stand_alone_function_decorated = my_shiny_new_decorator(stand_alone_function)
stand_alone_function_decorated()
```
> Наверное
, теперь
мы
бы
хотели
, чтобы
каждый
раз
, во
время
вызова
stand_alone_function
, вместо
неё
вызывалась
stand_alone_function_decorated.Для
этого
просто
перезапишем
stand_alone_function:
```python
stand_alone_function = my_shiny_new_decorator(stand_alone_function)
stand_alone_function()
```

> Собственно
, это
и
есть
декораторы.Вот
так
можно
было
записать
предыдущий
пример
, используя
синтаксис
декораторов:
```python


@
my_shiny_new_decorator
def another_stand_alone_function():
print("Оставь меня в покое")


another_stand_alone_function()

another_stand_alone_function = my_shiny_new_decorator(another_stand_alone_function)
```

> Пример
с
помидорами:
```python


def bread(func):
def wrapper():
print()
func()
print("<\______/>")

return wrapper


def ingredients(func):
def wrapper():
print("#помидоры#")
func()
print("~салат~")

return wrapper


def sandwich(food="--ветчина--"):
print(food)


sandwich()
sandwich = bread(ingredients(sandwich))
sandwich()
```
> И
используя
синтаксис
декораторов:
```python


@
bread
@ingredients
def sandwich(food="--ветчина--"):
print(food)


sandwich()
```
 
MyTetra Share v.0.65
Яндекс индекс цитирования