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.
  • Formatting: Convert Gregorian dates to Japanese era formatted strings using the strftime method.
  • Supported Eras: Meiji (明治), Taisho (大正), Showa (昭和), Heisei (平成), and Reiwa (令和).
  • First Year Notation: Supports the first-year notation (元年) for each era.
  • Custom Formatting: Allows custom formatting that includes both Japanese and Gregorian dates.

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 = "令和5年10月30日"
format_string = "%G年%m月%d日"
date_obj = jpdatetime.strptime(date_string, format_string)
print(date_obj)  # Output: 2023-10-30 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: "令和6年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 Meiji (from September 8, 1868) onwards. Eras prior to Meiji are not supported.
  • Date Range: Parsing and formatting are limited to the supported eras (Meiji, Taisho, Showa, Heisei, and Reiwa).
  • Future Eras: The library does not account for hypothetical future eras not explicitly defined in the eras list.
  • Locale Considerations: Month names and other locale-specific strings are in English. Localization for other languages is not provided.

Contributing

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

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.2.0.tar.gz (11.2 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.2.0-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for jpdatetime-1.2.0.tar.gz
Algorithm Hash digest
SHA256 1305c888c48f8b2f99407beb9446677b90659d5ffcfbb8edaa8c2fb2dde17fec
MD5 9f615c7a6d897064ddb1ae05d7c81844
BLAKE2b-256 48301e622a315e1dc4ddb2b2f138acf2435d2fa5643f93dc4e3f33901ab4b7ff

See more details on using hashes here.

File details

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

File metadata

  • Download URL: jpdatetime-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 11.8 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 378151dfe32453d84195c198b5cb8c2770159959624c0815a6c6342cc92422c5
MD5 b934659cf80dceb30981fa4b347cd1d2
BLAKE2b-256 8ce1d05d6d4f3e03c81eec434f08d1c6dc897c515a4e6fe64f421194bb4919ab

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