Skip to main content

command-line tool to convert a date and time to several time zones at once

Project description

tzconv: convert a date and time to several time zones at once

This Python package provides a small command-line utility to convert a YYYY-MM-DD HH:MM formatted date and time to several other time zones.

Installation

tzconv is available through PyPI:

$ python3 -m pip install tzconv

Alternatively, you can install it directly from the Codeberg Git repository:

$ git clone https://codeberg.org/gnyeki/tzconv
$ python3 -m pip install --user ./tzconv

Usage

Basic usage

tzconv uses the time zone information available through your operating system, so time zones have to be specified accordingly:

$ tzconv \
    -f America/New_York \
    -t Pacific/Galapagos \
    -t America/Santa_Isabel \
    "2023-04-25 10:00"
EDT: 2023-04-25 10:00 (America/New_York)
-06: 2023-04-25 08:00 (Pacific/Galapagos)
PDT: 2023-04-25 07:00 (America/Santa_Isabel)
$

Time zone names can be shortened as long as they remain unique. Initials, prefixes, and abbreviations are all recognized:

$ tzconv \
    -f ny \
    -t gal \
    -t san_i \
    "2023-04-25 10:00"
EDT: 2023-04-25 10:00 (America/New_York)
-06: 2023-04-25 08:00 (Pacific/Galapagos)
PDT: 2023-04-25 07:00 (America/Santa_Isabel)
$

Available time zones can be listed with the --list-tz option (or -l for short):

$ tzconv -l am/n
The following time zones are available that match 'am/n':

  America/Nassau, America/New_York, America/Nipigon, America/Nome,
  America/Noronha, America/North_Dakota/Beulah, America/North_Dakota/Center,
  America/North_Dakota/New_Salem, America/Nuuk
$

Imputing the current date and the current time

If the date is omitted, today's date is imputed:

$ tzconv -f ny -t aa 10:00
EDT: 2023-04-20 10:00 (America/New_York)
EAT: 2023-04-20 17:00 (Africa/Addis_Ababa)
$

If the time is omitted, too, then tzconv imputes the current time:

$ tzconv -f ny -t aa
EDT: 2023-04-20 15:03 (America/New_York)
EAT: 2023-04-20 22:03 (Africa/Addis_Ababa)
$

Daylight savings

Daylight savings can complicate conversions. However, thanks to the Python standard library, tzconv is aware of changes to daylight savings, and it infers the correct offsets. For example, in March 2023, New York switched to daylight savings two weeks earlier than Budapest. Notice the switch from EST/CET to EDT/CET, and finally to EDT/CEST:

$ tzconv -f ny -t bud "2023-03-07 10:00"
EST: 2023-03-07 10:00 (America/New_York)
CET: 2023-03-07 16:00 (Europe/Budapest)
$ tzconv -f ny -t bud "2023-03-14 10:00"
EDT: 2023-03-14 10:00 (America/New_York)
CET: 2023-03-14 15:00 (Europe/Budapest)
$ tzconv -f ny -t bud "2023-03-28 10:00"
EDT: 2023-03-28 10:00 (America/New_York)
CEST: 2023-03-28 16:00 (Europe/Budapest)
$

Custom shell commands for common conversions

If you have a project that spans several time zones, it is convenient to define a command for it in your .bashrc, .zshrc, or equivalent dot file, depending on what shell you use. For example, if you are using zsh, you can add the following to ~/.zshrc:

project_tz() {
    declare -a opts=(
        --from-tz America/New_York
        --to-tz America/Los_Angeles
        --to-tz America/Halifax
        --to-tz Asia/Karachi
        --to-tz Asia/Calcutta
    )

    if [ "$*" = "" ]; then
        tzconv $opts
    else
        tzconv $opts "$*"
    fi
}

Now you can reload ~/.zshrc and use project_tz as a shell command:

$ . ~/.zshrc
$ project_tz 2023-04-25 10:00
EDT: 2023-04-25 10:00 (America/New_York)
PDT: 2023-04-25 07:00 (America/Los_Angeles)
ADT: 2023-04-25 11:00 (America/Halifax)
PKT: 2023-04-25 19:00 (Asia/Karachi)
IST: 2023-04-25 19:30 (Asia/Calcutta)
$

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

tzconv-1.3.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

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

tzconv-1.3-py3-none-any.whl (6.0 kB view details)

Uploaded Python 3

File details

Details for the file tzconv-1.3.tar.gz.

File metadata

  • Download URL: tzconv-1.3.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for tzconv-1.3.tar.gz
Algorithm Hash digest
SHA256 6a49a0ff87515b88685c740c026b628e8630f80fcdb7a941044bdf96ce4532be
MD5 0ce21e814c010122c8473560c02c9d74
BLAKE2b-256 6dde368c090a396136a81c395ebc81d630fb2a7c4aa128908ea26d61cee01bf1

See more details on using hashes here.

File details

Details for the file tzconv-1.3-py3-none-any.whl.

File metadata

  • Download URL: tzconv-1.3-py3-none-any.whl
  • Upload date:
  • Size: 6.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for tzconv-1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 abb9b58747636cf15b15e33b9d229bfb4cb91aeba5bd5b46e18c5f0cb48a9d3a
MD5 15e810889508716d40e917ed38c30617
BLAKE2b-256 506dadda6ed180abb392df9dfb862740a1fe2bacab6c8053b6f0b04b1585734a

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