Проблема решена. Циклы прекрасно работают, просто
(f.tell() < length)
работало не корректно, поэтому цикл и пропускался.
Сейчас код выглядит вот так, и прекрасно работает:
import random
import logging
from aiogram import Bot, Dispatcher, executor, types
logging.basicConfig(level=logging.INFO)
bot = Bot(token="...")
dp=Dispatcher(bot)
@dp.message_handler(commands=['start', 'help'])
async def send_welcome(message: types.Message):
await message.reply("Hi!\nI'm EchoBot!\nPowered by aiogram.")
@dp.message_handler()
async def echo(message: types.Message):
f = open('users.txt', 'a+')
isuser = False
length = len(f.read())
f.seek(0)
user = types.User.get_current()
f.seek(0)
i=0
while (f.read(1)):
f.seek(f.tell()-1)
print(f.tell())
if (f.read(len(str(user.id))+4)=='id: '+str(user.id)):
isuser = True
break
while(f.read(1)!='\n'):
print('+' + str(f.tell()))
if (isuser == False):
f.write('id: '+ str(user.id) +'; name: '+str (user.full_name) +'; username: ' +str(user.username)+';\n')
f.close()
await message.answer(message.text)
if __name__ == '__main__':
executor.start_polling(dp, skip_updates=True)