Есть ли способ сравнить две даты без вызова strptime каждый раз в python? Я уверен, что с учетом моей проблемы другого пути нет, но я хочу убедиться, что проверил все варианты.
Я просматриваю очень большой файл журнала, в каждой строке есть дата, которую мне нужно сравнить, чтобы увидеть, находится ли эта дата в диапазоне двух других дат. Мне приходится преобразовывать каждую дату для каждой строки с помощью strptime, что вызывает большое узкое место;
Fri Sep 2 15:12:43 2016 output2.file
63518075 function calls (63517618 primitive calls) in 171.409 seconds
Ordered by: cumulative time
List reduced from 571 to 10 due to restriction <10>
ncalls tottime percall cumtime percall filename:lineno(function)
1 0.003 0.003 171.410 171.410 script.py:3(<module>)
1 0.429 0.429 171.367 171.367 scipt.py:1074(main)
1 3.357 3.357 162.009 162.009 script.py:695(get_data)
1569898 14.088 0.000 141.175 0.000 script.py:648(check_line)
1569902 6.899 0.000 71.706 0.000 {built-in method strptime}
1569902 31.198 0.000 64.805 0.000 /usr/lib64/python2.7/_strptime.py:295(_strptime)
1569876 15.324 0.000 43.170 0.000 script.py:626(dict_add)
4709757 23.370 0.000 23.370 0.000 {method 'strftime' of 'datetime.date' objects}
1569904 1.655 0.000 18.799 0.000 /usr/lib64/python2.7/_strptime.py:27(_getlang)
1569899 2.103 0.000 17.452 0.000 script.py:592(reverse)
Даты форматируются следующим образом;
current_date = 01/Aug/1995:23:59:53
И я сравниваю их вот так;
with open(logfile) as file:
for line in file:
current_date = strptime_method(line)
if current_date => end_date:
break
Есть ли альтернатива, когда дело доходит до сравнения дат?
Редактировать: Спасибо всем, в частности пользователю 2539738. Вот результаты, основанные на его/ее предложении, большая разница в скорости;
Fri Sep 2 16:14:59 2016 output3.file
24270567 function calls (24270110 primitive calls) in 105.466 seconds
Ordered by: cumulative time
List reduced from 571 to 10 due to restriction <10>
ncalls tottime percall cumtime percall filename:lineno(function)
1 0.002 0.002 105.466 105.466 script.py:3(<module>)
1 0.487 0.487 105.433 105.433 script.py:1082(main)
1 3.159 3.159 95.861 95.861 script.py:702(get_data)
1569898 21.663 0.000 77.138 0.000 script.py:648(check_line)
1569876 14.979 0.000 43.408 0.000 script.py:626(dict_add)
4709757 23.865 0.000 23.865 0.000 {method 'strftime' of 'datetime.date' objects}
1569899 1.943 0.000 15.556 0.000 script.py:592(reverse)
1 0.000 0.000 9.078 9.078 script.py:1066(print_data)
1 0.021 0.021 9.044 9.044 script.py:1005(print_ip)
10 0.001 0.000 7.067 0.707 script.py:778(ip_api)
strptime_method
? Какой-то свой код? Кроме того, вы используетеtime
(функциональный модуль для обработки дат и времени) илиdatetime
(модуль на основе классов для того же самого)? - person Vivian   schedule 02.09.2016current_time = datetime.datetime.strptime(date_from_line, "%d/%b/%Y:%H:%M:%S")
- person user1165419   schedule 02.09.2016time
, если она будет быстрее (я думаю, что она внутренне проще, хотя у меня нет возможности перепроверить исходный код прямо сейчас). - person Vivian   schedule 02.09.2016