token in pool.tokens:
calls.append([foo, func_name()])
func_name() может вызываться с аргументом token, а может без арг. Как это сделать? не могу найти решение((
Задай в func_name дефолтное значение: ```def func_name(token=None):```
думал об этом. Получается передавать аргумент всегда, в том числе функциям, которые его не используют. Не очень же?
1. Если у аргумента ф-ции есть значение по умолчанию - его можно не передавать. 2. Каким ещё функциям?
func_to_call это массив методов(ф-йи) для вызова.
А, понял. Можно достаточно просто закостылить - сделать func_to_call словарём двух массивов, и всю процедуру обернуть в цикл прохода по ключам словаря. Если ключ has_token - передаём token, no_token - не передаём
это с if has_token получается, так?
Ага. Грязно конечно и не очень-то питонячьи, но на скорую руку пойдёт
То есть в func_to_call лежат функции, часть из которых принимает аргумент, другая часть не принимает?
Можно сделать так: def func_zero(): pass def func_one(a): print(a) def func_two(a, b): print(a, b) def func_three(a, b, c): print(a, b, c) func_to_call = [ func_zero, func_one, func_two, func_three ] for func_name in func_to_call: if func_name.__code__.co_argcount == 0: func_name() elif func_name.__code__.co_argcount == 1: func_name(12) elif func_name.__code__.co_argcount == 2: func_name(12, 13) elif func_name.__code__.co_argcount == 3: func_name(12, 13, 14)
через inspect(https://docs.python.org/3/library/inspect.html) получи сигнатуру функции
Через inspect хуже.
Можно ещё так def func_name(token=None): ...
Обсуждают сегодня