Sobes.tech
Back to questions
Middle
2

# В настоящий момент документация и требования к работе этого кода точны # не на 100% и местами не актуальные, так что мы их тут не приводим. # Сам код работает на production серверах, результатами его работы пользуются разные # системы, некоторые из них написаны на коболе, а некоторые находятся на нефтяных # вышках в арктике и принимают входящие данные по однонаправленному сигналу со спутника. # Не хотелось бы что-то из этого сломать, а потом чинить. # Так что за требования "что и как должен делать этот код" нужно принимать то, как он по факту # сейчас работает. db = Model() def process(data): print("file size: " + str(len(data))) users_lines = open("/opt/data/users.txt").read().splitlines() resultat = [] for stroka in users_lines: trasictions_lines = open("/opt/data/transactions.txt").read().splitlines() process(trasictions_lines) for str2 in trasictions_lines: parts = str2.split() is_valid = db.check_transaction( user_id=parts[3], change=parts[4], ) if not re.search("\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2}\s+\d+\s+\w+\s+\d+\.\d+", str2): continue user_id = stroka.split()[0] regdate = db.get_regdate(user_id) if re.search("\d{4}-\d{2}-\d{2}", regdate) and re.search("\d+\.\d+", parts[4]): resultat.append(str2) if len(resultat) > 0: print("match")

Companies where asked
РунитиРунити

Answer from AI

sobes.tech AI

Этот код читает список пользователей из файла и для каждого пользователя обрабатывает транзакции из другого файла. Однако он содержит несколько проблем и потенциальных узких мест:

  1. Чтение файла транзакций внутри цикла по пользователям — файл /opt/data/transactions.txt открывается и читается заново для каждого пользователя, что крайне неэффективно. Лучше читать файл один раз вне цикла.

  2. Проверка формата строки транзакции регулярным выражением — если строка не соответствует формату, она пропускается.

  3. Проверка транзакции через метод db.check_transaction с параметрами user_id и change — результат проверки нигде не используется, возможно, это упущение.

  4. Формирование результата resultat только если дата регистрации пользователя и сумма изменения соответствуют шаблонам.

  5. Вывод "match" если есть хотя бы одна подходящая транзакция.

Чтобы не ломать текущую логику, можно улучшить код, например, так:

users_lines = open("/opt/data/users.txt").read().splitlines()
trasictions_lines = open("/opt/data/transactions.txt").read().splitlines()

resultat = []

for stroka in users_lines:
    user_id = stroka.split()[0]
    regdate = db.get_regdate(user_id)

    for str2 in trasictions_lines:
        if not re.search(r"\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2}\s+\d+\s+\w+\s+\d+\.\d+", str2):
            continue

        parts = str2.split()
        is_valid = db.check_transaction(user_id=parts[3], change=parts[4])
        
        if not is_valid:
            continue

        if re.search(r"\d{4}-\d{2}-\d{2}", regdate) and re.search(r"\d+\.\d+", parts[4]):
            resultat.append(str2)

if resultat:
    print("match")

Таким образом, мы:

  • Читаем файл транзакций один раз.
  • Проверяем валидность транзакций.
  • Используем результат проверки check_transaction.

Важный момент: поскольку код работает в production и влияет на разные системы, любые изменения нужно тщательно тестировать, чтобы не нарушить текущую логику.