Это потому, что asyncio и time.sleep () не совпадают вместе. Если бы вы были, я бы использовал asyncio.get_event_loop () вместо for loop и time.sleep ().Вот пример кода:
save_peers = [{"$type": "User", "id": 128521332, "accessHash": "9256310829016723727"},
{"$type": "User", "id": 928571821, "accessHash": "4540300829906797423"}
]
limit_message = 50000
bot_send_delay = 2
my_send_loop = asyncio.get_event_loop()
my_send_loop2 = asyncio.get_event_loop()
def send_message(bot, how_many, message_number, loop):
print("sending for ", message_number, " st time")
my_send_loop2.call_soon(send_message2, bot, len(save_peers), 0, my_send_loop2)
if message_number < how_many:
loop.call_later(bot_send_delay, send_message, bot, how_many, message_number + 1, loop)
else:
print("index finished")
def send_message2(bot, top, down, loop):
print("sending for ", down, " st time")
if down < top:
bot.send_message(TextMessage("TEXT"), Peer(peer_type=PeerType.user, peer_id=save_peers[down]["id"],
access_hash=save_peers[down]["accessHash"]),
success_callback=success, failure_callback=failure)
loop.call_later(bot_send_delay, send_message2, bot, top, down + 1, loop)
my_send_loop.call_soon(send_message, bot, limit_message, 0, my_send_loop)
updater.run()