fix: исправлен парсинг клубной карты из текста кабинета

- Клубная карта теперь извлекается как отдельное число ПОСЛЕ счета и суммы
- Формат: кабинет дата время СЧЕТ сумма КЛУБНАЯ_КАРТА
- Пример: 'Viposnova 16-11-2025 13:48:51 21-04-80-64-68-25-68 0.00 2521'
- Карта: 2521 (последнее 4-значное число), а НЕ последние 4 цифры счета
- Поиск карты после счета с пропуском сумм (содержат точку)
This commit is contained in:
2025-11-17 10:54:30 +09:00
parent 79eb66cf51
commit babaee0ca3
3 changed files with 39 additions and 35 deletions

View File

@@ -53,7 +53,7 @@ async def detect_account_input(message: Message, state: FSMContext):
if not accounts:
return # Счета не обнаружены, пропускаем
# Извлекаем номера клубных карт из последних 4 цифр каждого счета
# Извлекаем номера клубных карт и определяем владельцев
from ..core.services import UserService
from ..core.registration_services import AccountService
@@ -61,41 +61,34 @@ async def detect_account_input(message: Message, state: FSMContext):
accounts_with_owners = []
for account in accounts:
# Извлекаем только номер счета (без карты если есть)
# Парсим строку счета: может быть "КАРТА СЧЕТ" или просто "СЧЕТ"
parts = account.split()
account_number = parts[-1] if parts else account
# Извлекаем последние 4 цифры (номер клубной карты)
digits_only = account_number.replace('-', '').replace(' ', '')
if len(digits_only) >= 4:
club_card = digits_only[-4:] # Последние 4 цифры
# Ищем пользователя по номеру клубной карты
club_card = None
account_number = None
if len(parts) == 2:
# Формат: "КАРТА СЧЕТ" (например "2521 21-04-80-64-68-25-68")
club_card = parts[0]
account_number = parts[1]
elif len(parts) == 1:
# Формат: только "СЧЕТ" (например "21-04-80-64-68-25-68")
account_number = parts[0]
# Если есть номер клубной карты, ищем владельца
user = None
owner_info = None
if club_card:
user = await UserService.get_user_by_club_card(session, club_card)
if user:
owner_info = f"@{user.username}" if user.username else user.first_name
accounts_with_owners.append({
'account': account,
'club_card': club_card,
'owner': owner_info,
'user_id': user.id
})
else:
accounts_with_owners.append({
'account': account,
'club_card': club_card,
'owner': None,
'user_id': None
})
else:
# Счет неверного формата
accounts_with_owners.append({
'account': account,
'club_card': None,
'owner': None,
'user_id': None
})
accounts_with_owners.append({
'account': account,
'club_card': club_card,
'owner': owner_info,
'user_id': user.id if user else None
})
# Сохраняем счета в состоянии
await state.update_data(