NAME Date::Japanese::Era - Conversion between Japanese Era / Gregorian calendar SYNOPSIS use Date::Japanese::Era; # from Gregorian (month + day required) $era = Date::Japanese::Era->new(1970, 1, 1); # from Japanese Era $era = Date::Japanese::Era->new('炯下', 52); $name = $era->name; # '炯下' in EUC-jp (default) $gengou = $era->gengou; # same $year = $era->year; # 52 $gregorian = $era->gregorian_year; # 1977 DESCRIPTION Date::Japanese::Era handles conversion between Japanese Era and Gregorian calendar. METHODS codeset $codeset = Date::Japanese::Era->codeset; Date::Japanese::Era->codeset($encoding); sets / gets external encoding of Japanese era names. For example with the following code, input and output of era names are encoded in UTF-8. Date::Japanese::Era->codeset('utf8'); $era = Date::Japanese::Era->new($name, $year); # $name is UTF-8 print $era->name; # also UTF-8 You need Jcode module installed to make use of this feature. Otherwise, calls to codeset() are simply ignored (with warning). new $era = Date::Japanese::Era->new($year, $month, $day); $era = Date::Japanese::Era->new($era_name, $year); Constructs new Date::Japanese::Era instance. When constructed from Gregorian date, month and day is required. You need Date::Calc to construct from Gregorian. Name of era can be either of Japanese / ASCII. Input encodings can be specified via codeset(), suppose you have Jcode module installed. Default is EUC-JP. Exceptions are thrown when inputs are invalid (e.g: non-existent era name and year combination, unknwon era-name, etc.). name $name = $era->name; returns era name in Japanese. Encoding can be specified via codeset() class method. Default is EUC-JP. gengou alias for name(). name_ascii $name_ascii = $era->name_ascii; returns era name in US-ASCII. year $year = $era->year; returns year as Japanese era. gregorian_year $year = $era->gregorian_year; returns year as Gregorian. EXAMPLES use Date::Japanese::Era; # 2001 is H-13 my $era = Date::Japanese::Era->new(2001, 8, 31); printf "%s-%s", uc(substr($era->name_ascii, 0, 1)), $era->year; # to Gregorian my $era = Date::Japanese::Era->new('士喇', 13); print $era->gregorian_year; # 2001 CAVEATS * Days when era just changed are handled as newer (later) one. * Currently supported era is up to 'meiji'. * If someday current era (heisei) is changed, Date::Japanese::Era::Table should be upgraded. (Table is declared as global variable, so you can overwrite it if necessary). TODO * Date parameters can be in various format. I should replace Date::Simple or whatever for that. * Support earlier eras. AUTHOR Tatsuhiko Miyagawa <miyagawa@bulknews.net> This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. SEE ALSO the Date::Calc manpage, the Jcode manpage, the Date::Simple manpage