Skip to main content

A lightweight Python library for date and time operations.

Project description

DateTimeOps

Overview

DateTimeOps is a lightweight Python package providing convenient utilities for working with dates, times, and timestamps. It simplifies common datetime operations such as formatting, validation, conversion, offsets, and differences.

Features

  • Get current UTC or timezone-specific datetime.
  • Convert between different datetime formats.
  • Validate dates and check if they are in the future.
  • Perform date arithmetic (add/subtract days, months, offsets).
  • Calculate time differences in days, months, or timestamps.
  • Convert time formats (e.g., HH:MM:SS to seconds and vice versa).
  • Get first and last date of a given month.

Installation

You can install the package using pip:

pip install datetimeops

Usage

Import the package and use its functions:

from datetimeops.datetime_utils import now_utc, add_days_to_date, validate_date, change_date_format

# Get current UTC time
print(now_utc())  # '2025-02-13 14:30:00'

# Validate a date
print(validate_date("2025-05-01"))  # True
print(validate_date("Invalid Date"))  # False

# Change date format
print(change_date_format("2025-02-13 14:30:00", "%d-%m-%Y"))  # '13-02-2025'

# Add 10 days to a date
print(add_days_to_date("2025-02-13", 10))  # '2025-02-23 00:00:00'

Functions

Date & Time Retrieval

  • now_utc(fmt="%Y-%m-%d %H:%M:%S") → Returns the current UTC time.
  • now_tz(tz, fmt="%Y-%m-%d %H:%M:%S") → Returns the current time in the specified timezone.

Date Validation & Formatting

  • validate_date(d, fmt=None, chk_future_date=False) → Checks if a date is valid and optionally if it is in the future.
  • change_date_format(input_date, to_fmt, from_fmt="%Y-%m-%d %H:%M:%S") → Converts date format.

Epoch & Time Difference Calculations

  • epoch(date_str=None) → Returns Unix timestamp for a date or current time.
  • days_between_dates(start_date, end_date, fmt="%Y-%m-%d") → Returns the number of days between two dates.
  • months_between_dates(start_date, end_date) → Returns the number of months between two dates.
  • time_passed(start, end) → Returns time difference in human-readable format.

Date Arithmetic

  • add_days_to_date(date, days_to_add, to_fmt=None, from_fmt=None) → Adds days to a date.
  • add_months_to_date(date, months_to_add, to_fmt=None, from_fmt=None) → Adds months to a date.
  • offset_date(date, offset_type, offset_amount, to_fmt=None, from_fmt=None) → Applies an offset of years, months, days, etc.

Time Format Conversion

  • hhmmss_to_seconds(hhmmss) → Converts HH:MM:SS to total seconds.
  • seconds_to_hhmmss(seconds) → Converts seconds to HH:MM:SS format.

Miscellaneous

  • get_first_last_date_of_month(date, from_fmt, output_fmt) → Returns first and last date of a given month.
  • sleep_counter(seconds) → Displays a countdown timer.

Running Tests

To verify functionality, run the test suite using pytest:

pytest tests/

License

This project is licensed under the MIT License.

Contributions

Contributions are welcome! Feel free to open an issue or submit a pull request.

Author

Created by Kand Rishiraj.

Support

If you like this project, consider supporting it:

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

datetimeops-1.0.3.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

datetimeops-1.0.3-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

Details for the file datetimeops-1.0.3.tar.gz.

File metadata

  • Download URL: datetimeops-1.0.3.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for datetimeops-1.0.3.tar.gz
Algorithm Hash digest
SHA256 8c0ee620eee73d31e8ed91162bd8dfb6770a48a1a642ceb42551d76b7ec959b2
MD5 64407442357b99371b5251c815ea887c
BLAKE2b-256 049ebb2ec538e57fc2e899f541af373387c01db78eb3d8220b75c3e2ddd10aa5

See more details on using hashes here.

File details

Details for the file datetimeops-1.0.3-py3-none-any.whl.

File metadata

  • Download URL: datetimeops-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 6.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for datetimeops-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ab43e8c726c44b2a0ca0b496684ebce7dccaa42d1e9af3405c96f4fd5765e2c9
MD5 13451883ce51a8bcce139ebf6a727d9c
BLAKE2b-256 970be28a09c13a166518e95edb486df679f4da22386e6c106bb8e034b8b0a95f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page