This is a pytimeparse based project with the aim of optimizing functionality and providing stable support.
Copyright (c) 2023 Sergey Klyuykov <onegreyonewhite@mail.ru>
Licensed under the MIT License (see source file pytimeparse2.py for
details).
A small Python library to parse various kinds of time expressions, inspired by this StackOverflow question.
The single function pytimeparse2.parse defined in the library parses time
expressions like the following:
32m2h32m3d2h32m1w3d2h32m1w 3d 2h 32m1 w 3 d 2 h 32 m4:134:13:024:13:02.2662:04:13:02.2662 days, 4:13:02(uptimeformat)2 days, 4:13:02.2665hr34m56s5 hours, 34 minutes, 56 seconds5 hrs, 34 mins, 56 secs2 days, 5 hours, 34 minutes, 56 seconds1.2 m1.2 min1.2 mins1.2 minute1.2 minutes172 hours172 hr172 h172 hrs172 hour1.24 days5 d5 day5 days5.6 wk5.6 week5.6 weeks
It returns the time as a number of seconds (an integer value if possible, otherwise a floating-point number):
>>> from pytimeparse2 import parse
>>> parse('1.2 minutes')
72
For months and years, the library does not consider complications such as leap- years and leap-seconds. Instead, it assumes "30 days for a month" and "365 days for a year" as the basis for calculations with those units.
2 mo2 months3y3 years1y2mo3w4d5h6m7s8ms
For better capability with dates, use keyword as_timedelta=True which mark for function returns
value as datetime.timedelta or dateutil.relitivedelta.relativedelta (if installed):
>>> from pytimeparse2 import parse
>>> parse('24h', as_timedelta=True)
relativedelta(days=+1)
You can also forced disable dateutil support by calling disable_dateutil() before parse(...).
For returning support call enable_dateutil().
A number of seconds can be converted back into a string using the
datetime module in the standard library, as noted in
this other StackOverflow question:
>>> from pytimeparse2 import parse
>>> import datetime
>>> parse('1 day, 14:20:16')
138016
>>> str(datetime.timedelta(seconds=138016))
'1 day, 14:20:16'
- Speed up with Cython for some python versions.
- Use github actions for testing and releasing.