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:
@@ -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(
|
||||
|
||||
Reference in New Issue
Block a user