Skip to main content

The jpdatetime library extends Python's datetime to support Japanese eras (元号). It allows parsing and formatting dates in Japanese eras

Project description

JapaneseDatetime

Test PyPI - Version

The jpdatetime library extends Python's datetime to support Japanese eras (元号). It allows parsing and formatting dates using Japanese era names like Reiwa (令和), Heisei (平成), and more, including special support for first-year notation (元年).

Features

  • Parsing: Convert Japanese era date strings to Gregorian dates using the strptime method. This method supports date strings that include full-width characters and can handle years, months, and days written in kanji numerals.
  • Formatting: Convert Gregorian dates to Japanese era formatted strings using the strftime method.
  • Supported Eras: Support for conversion of eras from Reiki (霊亀), which began on October 3, 715, to Reiwa (令和).
  • First Year Notation: Supports the first-year notation (元年) for each era.

Installation

jpdatetime is available for installation via pip.

$ python -m pip install jpdatetime

GitHub Install

Installing the latest version from GitHub:

$ git clone https://github.com/new-village/JapaneseDatetime
$ cd JapaneseDatetime
$ python setup.py install

Usage

from jpdatetime import jpdatetime

# Parsing Japanese era date string to a datetime object
date_string = "平成三〇年十二月二四日"
format_string = "%G年%m月%d日"
date_obj = jpdatetime.strptime(date_string, format_string)
print(date_obj)  # Output: 2018-12-24 00:00:00

# Formatting a datetime object to a Japanese era date string
date = jpdatetime(2024, 10, 30)
formatted_date = date.strftime("%G年%m月%d日")
print(formatted_date)  # Output: "令和06年10月30日"

# Handling the first year of an era
date_string = "令和元年5月1日"
format_string = "%G年%m月%d日"
date_obj = jpdatetime.strptime(date_string, format_string)
print(date_obj)  # Output: 2019-05-01 00:00:00

# Formatting a datetime object for the first year of an era
date = jpdatetime(2019, 5, 1)
formatted_date = date.strftime("%G年%m月%d日")
print(formatted_date)  # Output: "令和元年5月1日"

# Using abbreviated era names
date_string = "令1年10月30日"
format_string = "%g年%m月%d日"
date_obj = jpdatetime.strptime(date_string, format_string)
print(date_obj)  # Output: 2019-10-30 00:00:00

date = jpdatetime(2019, 10, 30)
formatted_date = date.strftime("%g年%m月%d日")
print(formatted_date)  # Output: "令1年10月30日"

# Using English era names
date_string = "Heisei 30, April 1"
format_string = "%E, %B %d"
date_obj = jpdatetime.strptime(date_string, format_string)
print(date_obj)  # Output: 2018-04-01 00:00:00

date = jpdatetime(2018, 4, 1)
formatted_date = date.strftime("%E, %B %d")
print(formatted_date)  # Output: "Heisei 30, April 01"

# Using abbreviated English era names
date_string = "R1/05/01"
format_string = "%e/%m/%d"
date_obj = jpdatetime.strptime(date_string, format_string)
print(date_obj)  # Output: 2019-05-01 00:00:00

date = jpdatetime(2019, 5, 1)
formatted_date = date.strftime("%e/%m/%d")
print(formatted_date)  # Output: "R1/05/01"

strftime() and strptime() Format Codes

Directive Meaning Example
%G Full Japanese era name with year. Displays "令和元" for the first year and "平成30" for other years. 令和元, 平成30
%-G/%#G Full Japanese era name with year (without zero-padding). Displays non-zero-padded numbers for other years (e.g., "平成6"). 令和2, 平成6
%g Abbreviated Japanese era name (first character) with year. Shows "令01" for the first year and zero-padded numbers for other years (e.g., "平30"). 令01, 平30
%-g/%#g Abbreviated Japanese era name with year (without zero-padding). Shows "令1" for the first year and non-zero-padded numbers for other years (e.g., "平30"). 令1, 平6
%E Full English era name with year. Displays "Reiwa 01" for the first year and "Heisei 30" for other years. Reiwa 01, Heisei 30
%-E/%#E Full English era name with year (without zero-padding). Displays "Reiwa 1" for the first year and non-zero-padded numbers for other years (e.g., "Heisei 30"). Reiwa 1, Heisei 30
%e Abbreviated English era name (first letter) with year. Shows "R01" for the first year and "H30" for other years. R01, H30
%-e/%#e Abbreviated English era name with year (without zero-padding). Shows "R1" for the first year and non-zero-padded numbers for other years (e.g., "H30"). R1, H30

%Y, %m, %d, %B, etc.: Standard datetime format specifiers.

Limitation

  • Supported Eras: The library supports Reiki (from October 3, 715) onwards. Eras prior to Reiki are not supported.
  • Future Eras: The library does not account for hypothetical future eras not explicitly defined in the eras list.
  • Conversion rule of abbrivation Era: When converting from abbreviated era names (such as Rei, Hei, or R, H) to a date-time format, duplicate initial letters may exist among era names. In cases of duplication, the conversion defaults to the newer era.

Contributing

Feel free to open issues or submit pull requests if you have suggestions or improvements.

Reference

The era conversion in this library is based on the List of Japanese Eras on Wikipedia.

License

This project is licensed under the Apache-2.0 license.

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

jpdatetime-1.5.0.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

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

jpdatetime-1.5.0-py3-none-any.whl (18.3 kB view details)

Uploaded Python 3

File details

Details for the file jpdatetime-1.5.0.tar.gz.

File metadata

  • Download URL: jpdatetime-1.5.0.tar.gz
  • Upload date:
  • Size: 19.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for jpdatetime-1.5.0.tar.gz
Algorithm Hash digest
SHA256 73d084e0c679af51bf98b175fe3a63641b2153349f2c308c52db9e081b65981e
MD5 0963dc10cf8e9d556b9f0848140a01b0
BLAKE2b-256 6a49aba6027fed0a0956ba229ef77a0a7d257b3b4eda2d5da358733c72999a3f

See more details on using hashes here.

File details

Details for the file jpdatetime-1.5.0-py3-none-any.whl.

File metadata

  • Download URL: jpdatetime-1.5.0-py3-none-any.whl
  • Upload date:
  • Size: 18.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for jpdatetime-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 42fe636d1ccd10d739dadc92beb36c61643c4b196203032725227f8720fbaa5c
MD5 fd59f5b7fb054308f6c998f6ed48d2f6
BLAKE2b-256 06856ae7f9b7d49b021c100a3a8be4e5ab4fc7977ccbc9c7fe86736dbbf2d578

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