NAME
DateTime::Format::Japanese::Traditional - A Japanese DateTime Formatter For Traditional Japanese Calendar
SYNOPSIS
use DateTime::Format::Japanese::Traditional;
my $fmt = DateTime::Format::Japanese::Traditional->new();
# or if you want to set options,
my $fmt = DateTime::Format::Japanese::Traditional->new(
number_format => FORMAT_KANJI,
month_format => FORMAT_WAREKI_MONTH,
with_traditional_marker => 1
);
my $str = $fmt->format_datetime($dt);
my $dt = $fmt->parse_datetime("大化三年弥生三日丑三つ刻");
DESCRIPTION
This module implements a DateTime::Format module that can read tradtional Japanese date notations and create a DateTime::Calendar::Japanese object, and vice versa.
XXX WARNING WARNING WARNING XXX
Currently DateTime::Format::Japanese only supports Perl 5.7 and up.
This is because I'm ignorant in the ways of making robust regular
expressions in Perls <= 5.6.x with Jcode. If anybody can contribute to
this, I would much appreciate it
XXX WARNING WARNING WARNING XXX
METHODS
new()
This constructor will create a DateTime::Format::Japanese object. You may optionally pass any of the following parameters:
number_format - how to format numbers (default: FORMAT_KANJI)
month_format - how to format months (default: FORMAT_NUMERIC_MONTH)
with_traditional_marker - use traditional calendar marker (default: 0)
Please note that all of the above parameters only take effect for formatting, and not parsing. Parsing is done in a way such that it accepts any of the known formats that this module can produce.
$fmt->parse_datetime($string)
This function will parse a traditional Japanese date/time string and convert it to a DateTime::Calendar::Japanese object. If the parsing is unsuccessful it will croak. Note that it will try to auto-detect whatever encoding you're using via Encode::Guess, so you should be safe to pass any of UTF-8, euc-jp, shift-jis, and iso-2022-jp encoded strings.
This method can be called as a class function as well.
my $dt = DateTime::Format::Japanese::Traditional->parse_datetime($string);
# or
my $fmt = DateTime::Format::Japanese::Traditional->new();
my $fmt->parse_daettime($string);
FORMATTING METHODS
All of the following methods accept a single parameter, a DateTime::Calendar::Japanese object, and return the appropriate string representation.
my $dt = DateTime->now();
my $fmt = DateTime::Format::Japanese::Traditional->new(...);
my $str = $fmt->format_datetime($dt);
$fmt->format_datetime($dt)
Create a complete string representation of a DateTime::Calendar::Japanese object in Japanese
$fmt->format_ymd($dt)
Create a string representation of year, month, and date of a DateTime object in Japanese
$fmt->format_year($dt)
Create a string representation of the year of a DateTime::Calendar::Japanese object in Japanese
$fmt->format_month($dt)
Create a string representation of the month of a DateTime::Calendar::Japanese object in Japanese
$fmt->format_day($dt)
Create a string representation of the day (day of month) of a DateTime::Calendar::Japanese object in Japanese
$fmt->format_time($dt)
Create a string representation of the time (hour, minute, second) of a DateTime::Calendar::Japanese object in Japanese
OPTIONS
input_encoding()
output_encoding()
Get/Set the encoding that this module should expect to use.
number_format()
Get/Set the number formatting option. Possible values are:
- FORMAT_ROMAN
-
Formats the numbers in plain ascii roman numerals.
- FORMAT_KANJI
-
Formats numbers in kanji numerals without any unit specifiers.
- FORMAT_ZENKAKU
-
Formats numbers in zenkaku numerals (double-byte equivalent of roman numerals)
- FORMAT_KANJI_WITH_UNIT
-
Formats numbers in kanji numerals, with unit specifiers.
month_format()
Get/Set the month formatting option. Possible values are:
- FORMAT_NUMERIC_MONTH
-
Formats the month using numerals.
- FORMAT_WAREKI_MONTH
-
Formtas the month using traditional Japanese month names.
with_traditional_marker()
Get/Set the option to include a marker that declares the date as a traditional Japanese date.
AUTHOR
(c) 2004-2008 Daisuke Maki <daisuke@endeworks.jp<gt>.
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 394:
Non-ASCII character seen before =encoding in '$fmt->parse_datetime("大化三年弥生三日丑三つ刻");'. Assuming UTF-8