# Date Time Expression



[](http://www.wtfpl.net/about/)
`dte` is a WIP date-time processing language with focus on broad interpretation.
If you don't think it's intuitive, it's most likely unfinished.
It is strongly inspired by [pdd](https://github.com/jarun/pdd).

## How to use & What to know
`pip install dte`
### Conventions

- When there is margin for ambiguity, expressions are always interpreted with [highest units appearing before, complying with ISO-8601](https://preview.redd.it/2vjzrsib7ci61.png?width=2800&format=png&auto=webp&s=944b5176432419338cb2b13aeac10e61da1221f9), e.g.: `2021-06-13`, `2023 August 27` or `2019 Jul 20`
- Unix timestamps are both interpreted and output in seconds by default, but this is configurable
- When specifying time, just remember that `M` is for month and `m` is for minute
## Configuration File
`dte` tries to read a `config.json` file under config directory (`~/.config/dte/` on Linux). In it you can set the following options:
```
{
"timestamp_unit": "<seconds|milliseconds>"
"clock": "<24|12>",
"datetime_output_format": "<ISO8601|<format>>",
"comparison_tolerance_seconds": <float>,
"basedate_output_format": "%Y-%b",
"decimal_places": <integer>
}
```
### Dependencies
- [dateutil](https://github.com/dateutil/dateutil) handles month and year's complex operations
- [ply](https://github.com/dabeaz/ply) is a pure-Python implementation of the popular compiler construction tools lex and yacc
- [appdirs](https://github.com/ActiveState/appdirs) for reading config file in a cross-platform manner
## To do
- [ ] format(timepoint, fmt) (in keyword) units given current time field
- [ ] add custom/OS locale support (?)
- [ ] add tab-completion for:
- [ ] months
- [ ] units given current datetime field or RHS of `in` keyword
- [ ] "days until winter"
- [ ] run tests across a variety of locales
- [ ] add `show` function
- [ ] show clock for time
- [ ] show cal for date and basedate
# Examples
The following examples are generated based on tests run, so many results will be relative to the day it was tested. Every expression on the left side is valid syntax.
[//]: <> (BEGIN EXAMPLES)
`(T-1d).weekday` returns `Monday`
`(n + 180d)-180d == n` returns `True`
`(n + 181d)-180d != n` returns `True`
`(t + 180d)-180d == t` returns `True`
`-1d.weekday` returns `Monday`
`08h30` returns `8:30:00`
`1 in unix` returns `1`
`n - 1234` returns `18968 days, 22:02:45.828327`
`10h30 + 14h` returns `1 day, 0:30:00`
`2021 feb 14 12:00:00` returns `2021-02-14 12:00:00`
`seconds until 2021 feb 14 12:00:00` returns `-25601000.08`
`1-1-1 23:23:23` returns `0001-01-01 23:23:23`
`1-1-1 23:23m` returns `0001-01-01 23:23:00`
`1-1-1 23h:23` returns `0001-01-01 23:23:00`
`1-1-1 23h:23m` returns `0001-01-01 23:23:00`
`1-1-1 23m:23` returns `0001-01-01 00:23:23`
`1-1-1 23m:23s` returns `0001-01-01 00:23:23`
`1-1-1 23m:23S` returns `0001-01-01 00:23:23`
`1-1-1 23:23S` returns `0001-01-01 00:23:23`
`11h:20 AM` returns `11:20:00`
`11m:20 PM` returns `00:11:20`
`11h:20 am` returns `11:20:00`
`11h:20m pm` returns `23:20:00`
`11:20s PM` returns `00:11:20`
`2014 Jan 13` returns `2014-01-13`
`2014 January 13` returns `2014-01-13`
`1996.04.28` returns `1996-04-28`
`22h:22` returns `22:22:00`
`22:22:22` returns `22:22:22`
`22h:22m:22` returns `22:22:22`
`22h:22m:22s` returns `22:22:22`
`22:22m:22s` returns `22:22:22`
`22h:22:22s` returns `22:22:22`
`22:22:22s` returns `22:22:22`
`2020-Jan-27` returns `2020-01-27`
`6 pm` returns `18:00:00`
`6 pm + 1h` returns `19:00:00`
`6pm` returns `18:00:00`
`22m:22 + 4h` returns `4:22:22`
`1-1-1-1-1-1` returns `0:00:00`
`1610494238` returns `2021-01-12 20:30:38`
`1610494238+4h.weekday` returns `Wednesday`
`1610494238.weekday` returns `Tuesday`
`12h:00 AM != 12h:00 PM` returns `True`
`2014 Jan 13==2014 January 13` returns `True`
`1957-12-26 - t` returns `-23357 days, 0:00:00`
`1957-12-26 22:22:22 - t` returns `-23357 days, 22:22:22`
`1958-05-14 - 1958-05-16` returns `-2 days, 0:00:00`
`1d in hours` returns `24.00`
`1d in minutes` returns `1440.00`
`1d in seconds` returns `86400.00`
`1d` returns `1 day, 0:00:00`
`1d+0h22m` returns `1 day, 0:22:00`
`1d1m in hours` returns `24.02`
`1970 Jan 1 - 3h in unix` returns `0`
`1w` returns `7 days, 0:00:00`
`2020 Jan 27 + 1y == 2021 Jan 27` returns `True`
`2 < 1` returns `False`
`12h:00 pm != 12h:00 am` returns `True`
`22h+2m` returns `22:02:00`
`22h22m` returns `22:22:00`
`1y2M` returns `1 year, 2 months`
`0y2M` returns `2 months`
`-1y2M` returns `-1 year, -2 months`
`1M1d` returns `1 month, 1 day, 0:00:00`
`2h2m` returns `2:02:00`
`3h+3M` returns `3 months, 3:00:00`
`3M` returns `3 months`
`T-1.5d` returns `2021-12-05 12:00:00`
`T-10d` returns `2021-11-27`
`T.day` returns `7`
`T.weekday` returns `Tuesday`
`YD.day` returns `6`
`n` returns `2021-12-07 19:23:25.636872`
`next Sunday` returns `2021-12-12`
`2000-10-10 00:16` returns `2000-10-10 00:16:00`
`2000-10-10 16:00` returns `2000-10-10 16:00:00`
`seconds until 3000 Apr 10` returns `30873328594.02`
`seconds since 3000 Apr 10` returns `-30873328593.93`
`next Sunday == last sunday` returns `False`
`next Sunday != last sunday` returns `True`
`last Sunday == next sunday` returns `False`
`last Sunday != next sunday` returns `True`
`last sunday in 2021` returns `2021-12-26`
`first sunday in 2021` returns `2021-01-03`
`1st sunday in 2021` returns `2021-01-03`
`2012-12-13-3y.weekday` returns `Sunday`
`t - next Sunday` returns `-5 days, 0:00:00`
`wait .001s` returns ``
`wait until (n+.001s)` returns ``
`weekday 0` returns `Wednesday`
`Jan 2014` returns `2014-Jan`
`first friday in April 2014` returns `2014-04-04`
`1st friday in April 2014` returns `2014-04-04`
`first sun in April 2021` returns `2021-04-04`
`1st sun in April 2021` returns `2021-04-04`
`yd-5h` returns `2021-12-05 19:00:00`
`1957-12-26 22:22:22 in unix` returns `-379118258`
`5m+5m` returns `0:10:00`
`1h in seconds` returns `3600.00`
`1 hour in seconds` returns `3600.00`
`2s2s` returns `0:00:04`
`1996 August 28 9 AM` returns `1996-08-28 09:00:00`
`seconds until tomorrow` returns `16591.84`
`seconds until 11 pm` returns `12991.76`
`next month` returns `2022-01-01`
`first friday in next month` returns `2022-01-07`
`1st friday in next month` returns `2022-01-07`
`first friday in april` returns `2022-04-01`
`1st friday in april` returns `2022-04-01`
`2014 01` returns `2014-Jan`
`6pm+1h` returns `19:00:00`
`days until 2030-12-25` returns `3304.19`
`last fri in 2014 December` returns `2014-12-26`
`last fri in 2014 Dec` returns `2014-12-26`
`last fri in Dec 2014` returns `2014-12-26`
`yesterday==thursday` returns `False`
`yesterday==thu` returns `False`
`weekday tm` returns `Wednesday`
`(weekday t+100d)` returns `Thursday`
`(weekday t+100d)==100d.weekday` returns `True`
`weekday t+100d` returns `Thursday`
`monday+1d` returns `2021-12-07`
`next mon + 1d` returns `2021-12-14`
`days until next mon` returns `5.19`
`days until mon` returns `-1.81`
`today==mon` returns `False`
`seconds in 24h` returns `86400.00`
`Jan 2014 + 1M` returns `2014-02-01`
`2014 Jan + 1M` returns `2014-02-01`
`-1d + 2020-10-10` returns `2020-10-09`
`2nd sunday in 2021` returns `2021-01-10`
`3rd sunday in 2021` returns `2021-01-17`
`4th sunday in 2021` returns `2021-01-24`
`5th sunday in 2021` returns `2021-01-31`
`4th wed in august` returns `2021-08-25`
`august` returns `2021-Aug`
`t 1am` returns `2021-12-07 01:00:00`
`t 1:00` returns `2021-12-07 01:00:00`
`t 1:00 == t 1am` returns `True`
`(2020-10-10+1d) 3pm` returns `2020-10-11 15:00:00`
`1am t` returns `2021-12-07 01:00:00`
`1am t == t 1am` returns `True`
`t+1d 08h30` returns `2021-12-08 08:30:00`
`april+1M` returns `2022-05-01`
`last sun in 2021` returns `2021-12-26`
`days until Jan 2030` returns `2946.19`
`2020-01-29 + (1 year + 1 month)` returns `2021-02-28`
`friday day 13 in 2015.weekday` returns `Friday
Friday
Friday`
`friday day 13 in August 2021` returns `2021-08-13`
`friday day 13 in August 2021.weekday` returns `Friday`
`friday day < 8 in Jan 2015` returns `2015-01-02`
`friday day < 13 in 2014 sep` returns `2014-09-05
2014-09-12`
`day 13 friday in 2021` returns `2021-08-13`
`1970 january 1st` returns `1970-01-01`
`jan 1 + 99999M` returns `8334-04-01`