Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
 Аватар для SW Developer
97 / 93 / 81
Регистрация: 10.01.2016
Сообщений: 663
Записей в блоге: 13

Декораторы

04.11.2021, 16:02. Показов 2297. Ответов 27
Метки нет (Все метки)

Что за хрень?
Миниатюры
Декораторы  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.11.2021, 16:02
Ответы с готовыми решениями:

Декораторы
Добрый день! Не получается сделать задачу. Вот условие: На вход программы поступает строка из целых чисел, записанных через пробел....

Декораторы
здравствуйте заинтересовал сабж, нашёл в сети @decorator_function def hello_world(): print('Hello world!') hello_world() ...

Декораторы
Объясните, почему если добавить две строчки последние, то время выводит, а если не добавить, то не выводит. from datetime import...

27
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,696
Записей в блоге: 29
05.11.2021, 14:53
Цитата Сообщение от SW Developer Посмотреть сообщение
memo.clear()
а зачем весь то словарь чистишь? надо по идее удалять те значения что запрошены конкретное количество раз

Добавлено через 57 секунд
счетчик можно просто целым числом
0
 Аватар для SW Developer
97 / 93 / 81
Регистрация: 10.01.2016
Сообщений: 663
Записей в блоге: 13
05.11.2021, 14:59  [ТС]
Welemir1, я думал, весь кэш чистить.)
Счетчик пытался сделать просто числом, но как сохранять значение в памяти?
0
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
05.11.2021, 16:03
Цитата Сообщение от SW Developer Посмотреть сообщение
Счетчик пытался сделать просто числом, но как сохранять значение в памяти?
nonlocal в области видимости замыкания.
1
 Аватар для SW Developer
97 / 93 / 81
Регистрация: 10.01.2016
Сообщений: 663
Записей в блоге: 13
05.11.2021, 16:05  [ТС]
Arsegg, понял. Почитаю. Спс.
0
 Аватар для SW Developer
97 / 93 / 81
Регистрация: 10.01.2016
Сообщений: 663
Записей в блоге: 13
05.11.2021, 22:31  [ТС]
Python
1
2
3
4
5
6
7
def decorate(f):
    count = 0
    def wrapper(*args):
        nonlocal count
        count += 1
        return f(*args)
    return wrapper
Так?
0
 Аватар для SW Developer
97 / 93 / 81
Регистрация: 10.01.2016
Сообщений: 663
Записей в блоге: 13
06.11.2021, 12:21  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
а зачем весь то словарь чистишь? надо по идее удалять те значения что запрошены конкретное количество раз
Что-то никак не пойму, как это реализовать. (

Добавлено через 1 минуту
Как прикрутить счетчик к конкретному ключу в словаре?

Добавлено через 5 минут
Еще один словарь создать, где значением ключа будет счетчик?
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,696
Записей в блоге: 29
06.11.2021, 12:24
SW Developer, хранить кортежи например то есть ключ = (счетчик, значение), если счетчки станет 0 то пересчитывать.
Что с прочтением книги по декораторам?
1
 Аватар для SW Developer
97 / 93 / 81
Регистрация: 10.01.2016
Сообщений: 663
Записей в блоге: 13
06.11.2021, 14:12  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
Что с прочтением книги по декораторам?
Изучаю!

Добавлено через 1 час 40 минут
Вроде получилось!
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
def decorate(arg):
    def memoize_func(f):
        memo = dict()
        memo_counter = dict()
 
        def wrapper(*args):
            if args in memo and memo_counter[args] == arg:
                memo.pop(args)
                memo_counter.pop(args)
                pass
            elif args in memo:
                memo_counter[args] += 1
                pass
 
            print(f'Run with args={args}, memo={memo}')
            if args not in memo:
                memo_counter[args] = 0
                memo[args] = f(*args)
                # print((memo[args]))
            return memo[args]
        return wrapper
    return memoize_func
 
 
count = 2  # счетчик
 
 
@decorate(count)
def func(a, b):
    print(f'    Run func({a}, {b})')
    return a ** b
 
 
print(func(3, 5), '\n')
print(func(3, 5), '\n')
print(func(3, 5), '\n')
print(func(3, 5), '\n')
print(func(3, 4), '\n')
print(func(3, 5), '\n')
print(func(3, 5), '\n')
print(func(3, 5), '\n')
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.11.2021, 14:12

Декораторы функций
Вводятся два списка (каждый с новой строки) из слов, записанных через пробел. Имеется функция, которая преобразовывает эти две строки в...

Python Декораторы
Питон пока что знаю поверхностно. почитал про декораторы. Понял что с их помощью модно оборачивать один метод в другой. Но вот...

Декораторы - объясните новичку:)
Всем доброго времени прочтения! Начинаю изучать декораторы, и никак не могу понять одну вещь: def decorator(function): def...

Как прикрепить декораторы в цикле?
Делаю бота в телеграмме,который считывает сообщения с нескольких аккаунтов.Для получение сообщений используется следующая конструкция: ...

Декораторы функций в языке Python
Декораторы функций в языке Python Вводятся два списка (каждый с новой строки) из слов, записанных через пробел. Имеется функция,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
28
Ответ Создать тему
Новые блоги и статьи
[golang] Insert Delete GetRandom O(1) (Leetcode: 380)
alhaos 16.06.2026
Insert Delete GetRandom O(1) Сложность: Medium Источник: LeetCode 380 Задача Реализовать структуру данных RandomizedSet, которая поддерживает следующие операции за O(1) в среднем:
Свет в конце тоннеля
kumehtar 16.06.2026
Поймал себя на одной мысли. Раньше мне всегда казалось неправильным жить без чёткого понимания, куда всё идёт. Будто я иду по дороге судьбы, но не знаю, куда она ведёт. А раз не знаю — значит,. . .
[golang] Реализация стека с поддержкой получения минимального элемента за O(1)
alhaos 16.06.2026
Min Stack Сложность: Medium Источник: LeetCode 155 Задача: Реализовать стек который поддерживает push, pop, top и получение минимального элемента за O(1). Методы:
[golang] Конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов.
alhaos 10.06.2026
Задача Реализовать конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов. Сигнатура func Fetch(urls string, maxConcurrent int) Result Пример urls :=. . .
[golang] Состояние гонки (race condition)
alhaos 10.06.2026
Состояние гонки (race condition) Состояние гонки (Race Condition) — это ошибка, возникающая при одновременном доступе нескольких горутин к одним и тем же данным без должной синхронизации. При этом. . .
Взрослые отношения, и почему они не получаются
kumehtar 09.06.2026
Когда в детстве ребёнок не получает от родителей чего-то важного, он лишается не просто приятных переживаний, а основы для формирования определённых внутренних качеств и навыков. Если ребёнок не. . .
[golang] Worker Pool
alhaos 09.06.2026
Worker Pool Worker Pool — паттерн конкурентной обработки задач в Go. Суть: фиксированное количество горутин-воркеров читают задачи из общего канала и пишут результаты в общий канал результатов. . . .
[golang] Pipeline
alhaos 08.06.2026
Pipeline Pipeline — паттерн конкурентной обработки данных в Go. Суть: данные проходят через цепочку независимых стадий, каждая из которых работает в своей горутине и общается с соседями через. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru