для aiogram:
async def waiter_init():
async def waiter_loop():
while True:
_ = yield
await asyncio.sleep(1)
waiter = waiter_loop()
await waiter.asend(None)
original_send_message = bot.send_message
async def send_message(*args, **kwargs):
await waiter.asend(None)
await original_send_message(*args, **kwargs)
bot.send_message = send_message
?
А почему не asyncio.sleep? Например можно декоратором добавить к каждому таску Ну или я контекст вопроса не уловил. Пока мне кажется что код мог бы быть гораздо проще
ну поспит отправка чуть-чуть только если придёт тысяча сообщений, вся тысяча будет спать параллельно
Да, это я понимаю... хм я еще подумаю
я ошибся с порядком строк await waiter.asend(None) должна быть до await original_send_message(*args, **kwargs) иначе и от этого нагромождения толка не будет
Может подойдет Lock для отправки сообщений и просто делать паузу прежде чем его отпустить? https://docs.python.org/3/library/asyncio-sync.html Я бы в эту сторону рыл)
можно и так, но мой вариант мне больше нравится
Обсуждают сегодня