Calcuate a dynamic time window.
Project description
Calculate Time Window
Create a lookback window or calculate expiration from "now".
Is this just a wrapper around datetime.timedelta()?
Yes and no. The goal is to simplify setting start and end seconds when creating a dynamic range of timestamps for a lookback without calling datetime.timedelta() and datetime.replace() multiple times in scripts. If this sounds good because you've had to do this before, great! If not, just use datetime.
This creates start and end timestamps in multiple formats. Provide start "minutes ago", ending "minutes ago" (0 for "now"), and seconds for each as part of the respective starting or ending minute. Providing "5 minutes ago, 5 seconds" will be 5 minutes ago, 5 seconds into that minute. You can also provide weeks, days, and hours for start and end. "Now" is calculated at instance creation, but can be passed at that time. If you need explicit timestamps, not ones relative to "now", just use datetime.
You then use the timestamp formats created as start and end arguments for your scripts and tools.
Setup
uv add calculate_time_window
# or
python3 -m pip install calculate_time_window
Usage
from calculate_time_window import CalculateTimeWindow as ctw
c = ctw(start_minutes_ago=5).calculate()
print(c)
# displays a dictionary of results
Use Case 1
- you need to call an API for a range of data, but your scheduler doesn't run scripts perfectly on the minute, and you do "x minutes ago" queries
- you create
CalculateTimeWindow(start_minutes_ago=3, end_minutes_ago=1) - you receive a dictionary of
- start timestamps set 3 minutes ago, 0 seconds and 0 milliseconds into that minute, in multiple formats
- end timestamps set 1 minute ago, 59 seconds and 999 milliseconds into that minute, in multiple formats
"now_ms": "2026-04-02 02:06:30.244",
"start_ms": "2026-04-02 02:03:00.000",
"end_ms": "2026-04-02 02:05:59.999",
"start_tms": "2026-04-02T02:03:00.000",
--snip--
Use Case 2
- same as use case #1, but for some reason you need 13 seconds of data, and want epoch timestamps
- you create
CalculateTimeWindow(start_minutes_ago=3, end_minutes_ago=1, start_seconds=7, end_seconds=13) - you receive a dictionary of
- start timestamps set 3 minutes ago, 7 seconds and 0 milliseconds into that minute, in multiple formats
- end timestamps set 1 minute ago, 13 seconds and 999 milliseconds into that minute, in multiple formats
--snip--
"now_tms": "2026-04-02T02:06:30.244",
"now_epoch": 1775095590.244,
--snip--
"start_tms": "2026-04-02T02:03:07.000",
"end_tms": "2026-04-02T02:05:13.999",
"start_epoch": 1775095387.0,
"end_epoch": 1775095513.999,
--snip--
Use Case 3
- you receive a token response that includes a lifetime or expiration measures in seconds, and want to calculate timestamps upon reception
- you create
CalculateTimeWindow(expires_in=600, expires_only=True)- note that "now" is defined at instance creation, or by providing a "now" argument using a
datetimeobject
- note that "now" is defined at instance creation, or by providing a "now" argument using a
- you receive a dictionary of expiration timestamps, without
now_*,start_*, andend_*due to settingexpires_only=True
--snip--
"exp_ms": "2026-04-02 02:16:30.245",
"exp_us": "2026-04-02 02:16:30.245090",
"exp_tms": "2026-04-02T02:16:30.245",
"exp_tus": "2026-04-02T02:16:30.245090",
"exp_epoch": 1775096190.24509,
"exp_epochint": 1775096190,
"exp_epochms": 1775096190245
--snip--
Response Value Meanings
_iso: ISO8601 timestamp as created usingdatetime.isoformat()without further modification_msand_tms: timestamp (with and without "T" separator) rounded to milliseconds (3 decimal places)_usand_tus: timestamp (with and without "T" separator) rounded to microseconds (6 decimal places)_epoch: epoch timestamp with microseconds (float)_epochint: epoch timestamp rounded to nearest second (int)_epochms: epoch in milliseconds (epoch * 1000)
Instance Defaults
start_weeks_ago: Optional[int] = 0,
end_weeks_ago: Optional[int] = 0,
start_days_ago: Optional[int] = 0,
end_days_ago: Optional[int] = 0,
start_hours_ago: Optional[int] = 0,
end_hours_ago: Optional[int] = 0,
start_minutes_ago: Optional[int] = 0,
end_minutes_ago: Optional[int] = 0,
start_seconds: Optional[int] = 0,
end_seconds: Optional[int] = 59,
start_milliseconds: Optional[int] = 0,
end_milliseconds: Optional[int] = 999,
start_microseconds: Optional[int] = 0,
end_microseconds: Optional[int] = 999999,
expires_in: Optional[int] = 0,
expires_only: Optional[bool] = False,
now: Optional[datetime] = None
Usage Examples
CalculateTimeWindow()
CalculateTimeWindow(start_minutes_ago=3, end_minutes_ago=1, start_seconds=7, end_seconds=13)
CalculateTimeWindow(expires_in=600)
#
past_time = datetime.now() - timedelta(days=1)
calc6 = CalculateTimeWindow(start_minutes_ago=3, now=past_time)
Sample Output
produced with json.dumps(x, indent=4)
CalculateTimeWindow(start_weeks_ago=2, start_days_ago=1, start_hours_ago=2, start_minutes_ago=3, end_weeks_ago=1, end_days_ago=2, end_hours_ago=3, end_minutes_ago=1, start_seconds=7, end_seconds=13).calculate()
{
"now_iso": "2026-04-02T02:06:30.244957+00:00",
"now_ms": "2026-04-02 02:06:30.244",
"now_us": "2026-04-02 02:06:30.244957",
"now_tms": "2026-04-02T02:06:30.244",
"now_tus": "2026-04-02T02:06:30.244957",
"now_epoch": 1775095590.244957,
"now_epochint": 1775095590,
"now_epochms": 1775095590244,
"start_iso": "2026-03-18T00:03:07+00:00",
"end_iso": "2026-03-23T23:05:13.999999+00:00",
"start_ms": "2026-03-18 00:03:07.000",
"end_ms": "2026-03-23 23:05:13.999",
"start_us": "2026-03-18 00:03:07.000000",
"end_us": "2026-03-23 23:05:13.999999",
"start_tms": "2026-03-18T00:03:07.000",
"end_tms": "2026-03-23T23:05:13.999",
"start_tus": "2026-03-18T00:03:07.000000",
"end_tus": "2026-03-23T23:05:13.999999",
"start_epoch": 1773792187.0,
"end_epoch": 1774307113.999999,
"start_epochint": 1773792187,
"end_epochint": 1774307113,
"start_epochms": 1773792187000,
"end_epochms": 1774307113999
}
CalculateTimeWindow(expires_in=600, expires_only=True).calculate()
{
"exp_iso": "2026-04-02T02:16:30.245262+00:00",
"exp_ms": "2026-04-02 02:16:30.245",
"exp_us": "2026-04-02 02:16:30.245262",
"exp_tms": "2026-04-02T02:16:30.245",
"exp_tus": "2026-04-02T02:16:30.245262",
"exp_epoch": 1775096190.245262,
"exp_epochint": 1775096190,
"exp_epochms": 1775096190245
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file calculate_time_window-0.2.1.tar.gz.
File metadata
- Download URL: calculate_time_window-0.2.1.tar.gz
- Upload date:
- Size: 17.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9780868f109f1ce4d503829453598df51a6ea1a359c485f1b3efd1dd2934824e
|
|
| MD5 |
5c87c7bddfa601d6ec9a3cf014602c4a
|
|
| BLAKE2b-256 |
5b5f3f4edf00fcc883116c8f4151f9617bd26f6dd726f29c2f6874ed49a0a89c
|
File details
Details for the file calculate_time_window-0.2.1-py3-none-any.whl.
File metadata
- Download URL: calculate_time_window-0.2.1-py3-none-any.whl
- Upload date:
- Size: 17.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b9cb24934755e6e75a04380b9e1f1d846cb41522c5289ffbc74dd3c36974909f
|
|
| MD5 |
21719a81afc865581b33db108c7fd638
|
|
| BLAKE2b-256 |
76dc233c9f59592ec7a30ecd0d8d1a60baa39564d48a31e598f7227746dbd6e1
|