tgoop.com/pyproglib/7038
Create:
Last Update:
Last Update:
В Python всё чаще приходится выбирать между sync и async реализациями (а иногда ещё и писать обе).
Если вам надоело дублировать код или разбираться в тёмных углах asyncio, вот две очень лёгкие и практичные альтернативы.
С помощью шаблона вы пишете *один* фрагмент кода, а библиотека генерирует:
— обычную функцию (func())
— async-версию (await func())
— генератор (for _ in func():)
Пример:
@transfunction
def template():
print('so, ', end='')
with sync_context:
print("it's just usual function!")
with async_context:
print("it's an async function!")
with generator_context:
print("it's a generator function!")
yield
Хотите всё автоматически — используйте
@superfunction, и функция сама поймёт, как её вызвали:~my_superfunction() # обычный вызов
await my_superfunction() # async-исполнение
for x in my_superfunction(): # генератор
Если вы когда-нибудь думали «asyncio слишком сложный для такой простой задачи» — эта библиотека для вас.
tinyio — микроскопический event loop с безопасной обработкой ошибок и простейшим API:
def slow_add_one(x):
yield tinyio.sleep(1)
return x + 1
def foo():
a, b = yield [slow_add_one(3), slow_add_one(4)]
return a, b
loop = tinyio.Loop()
print(loop.run(foo())) # → (4, 5)
— вместо
await используется yield— если ошибка случается в одной корутине — автоматически отменяются все, чтобы не было скрытого «зомби»-кода
— нет
Task, Future, TaskGroup — только Loop, sleep, run_in_threadpip install transfunctions
pip install tinyio
#буст

