NAME
Tripletail::DateTime - 日付と時刻
SYNOPSIS
my $dt = $TL->newDateTime('2006-02-17 15:18:01');
$dt->addDay(1);
$dt->addSecond(-1);
print $dt->toStr('rfc822'); # Fri, 18 Feb 2006 15:18:00 JST
DESCRIPTION
日付と時刻を扱うクラス。グレゴリオ歴にのみ対応している。精度は秒。 うるう秒や夏時間を考慮しない。
METHODS
$TL->newDateTime
-
$dt = $TL->newDateTime; # 現在時刻 $dt = $TL->newDateTime($str); # 文字列をパース
Tripletail::DateTime オブジェクトを生成。 二番目の形式では、文字列から日付や時刻をパースする。
存在しない日付が指定された場合は、それが自動的に補正される。 例えば次の 2 行は同じ結果になる。
$dt = $TL->newDateTime('2000-04-31'); $dt = $TL->newDateTime('2000-05-01');
但し、次の行はパースに失敗する。
$dt = $TL->newDateTime('2000-99-99'); # 正しい形式に沿っていない
パースに失敗した場合はdieする。時刻が与えられない場合は 0 時 0 分 0秒 に設定され、タイムゾーンが与えらない場合は localtime と gmtime の差か ら求めた値が設定される。パースできる形式は次の通り。
- 一般
-
YYYY-MM-DD YYYY-MM-DD HH:MM:SS
ハイフンやコロンは別の記号であっても良く、何も無くても良い。 例:
YYYY@MM@DD YYYY/MM/DD HH.MM.SS YYYYMMDD YYYYMMDDHHMMSS
- date コマンド
-
Wdy Mon DD HH:MM:SS TIMEZONE YYYY (Fri Feb 17 11:24:41 JST 2006)
- Apache access_log
-
DD/Mon/YYYY:HH:MM:SS +TTTT (17/Feb/2006:11:24:41 +0900)
- Apache error_log
-
Wdy Mon DD HH:MM:SS YYYY (Fri Feb 17 11:24:41 2006)
- Apache directory index
-
DD-Mon-YYYY HH:MM:SS
- RFC 822
-
Wdy, DD-Mon-YY HH:MM:SS TIMEZONE (Fri, 17 Feb 06 11:24:41 +0900) Wdy, DD-Mon-YYYY HH:MM:SS TIMEZONE (Fri, 17 Feb 2006 11:24:41 +0900)
- RFC 850
-
Wdy, DD-Mon-YY HH:MM:SS TIMEZONE (Fri, 17-Feb-06 11:24:41 JST) Wdy, DD-Mon-YYYY HH:MM:SS TIMEZONE (Fri, 17-Feb-2006 11:24:41 JST)
- W3C Date and Time
-
YYYY YYYY-MM YYYY-MM-DD YYYY-MM-DDTHH:MMTzd (2006-02-17T11:40+09:00) YYYY-MM-DDTHH:MM:SSTzd (2006-02-17T11:40:10+09:00) YYYY-MM-DDTHH:MM:SS.sTzd (2006-02-17T11:40:10.45+09:00)
ここで Tzd とはタイムゾーン指定であり、+hh:mm / -hh:mm / 'Z' の何れか の形式で表される。Z は UTC を表す。例:
2006-02-17T11:40:10Z
最後の形式の .s は時刻の端数を表すものであるが、このクラスの精度は秒で あるので、端数はパース後に切り捨てられる。
- TAI64N
-
@4000000043f529721590b6bc
一秒未満は切り捨てられる。
clone
-
$dt2 = $dt->clone;
DateTimeオブジェクトを複製して返す。
set
-
$dt->set; $dt->set($str);
引数はコンストラクタと同じ。
setEpoch
-
$dt->setEpoch($epoch);
エポックからの秒数を設定する。このクラスでエポックとは gmtime(0) の返 す日付と時刻を云う。負の値を与えた場合は、エポック以前の日付/時刻に設 定される。
setJulianDay
-
$dt->setJulianDay($julian);
ユリウス日を設定する。小数で指定された場合は、その値から時刻を求める。
setYear
-
$dt->setYear(2006);
年を設定する。引数は、現在設定されているタイムゾーンでの値として解釈さ れる。
setMonth
-
$dt->setMonth(1);
月を設定する。負の値 n を与えた場合は、最大値(setMonthの場合は12) + 1 + n が与えられたものと見なす。例えば setMonth(-1) は setMonth(12) に等 しい。
引数が0または13以上である場合、及び-13以下である場合は die する。
また、月を変更する事により日が存在する範囲から外れた場合は、日が最終日 に設定される。例えば1月31日で setMonth(4) すると4月30日になる。
setDay
setHour
setMinute
setSecond
-
setMonth と同様。負の値を与えた場合等の動作も setMonth に準じる。
setTimeZone
-
$dt->setTimeZone(); # localtimeとgmtimeの差から計算 $dt->setTimeZone(9); # +09:00 に設定 $dt->setTimeZone('+0900'); # +09:00 に設定 (RFC 822) $dt->setTimeZone('+09:00'); # +09:00 に設定 (W3C) $dt->setTimeZone('gmt'); # +00:00 に設定
タイムゾーンを設定する。タイムゾーンを変更すると、絶対時間であるエポッ ク秒やユリウス日は変化しないが、getSecond等で返される日付や時刻等が変 化する。
getEpoch
-
$epoch = $dt->getEpoch;
エポック秒を返す。エポック以前の日付と時刻では負の値が返る。
getJulianDay
-
$julian = $dt->getJulianDay;
ユリウス日を小数で返す。
getYear
-
$year = $dt->getYear;
年を返す。現在設定されているタイムゾーンでの値が返される。
getMonth
-
$mon = $dt->getMonth; # 数値 1-12 で返す。
月を返す。
getDay
getHour
getMinute
getSecond
-
getYearと同様。
getWday
-
$wday = $dt->getWday; # 数値 0-6 で返す。0が日曜、1が月曜である。
曜日を返す。数値 0-6 で返す。0が日曜、1が月曜である。
getTimeZone
-
$tz = $dt->getTimeZone(); # 時間で返す
タイムゾーンを時間単位で返す。端数がある場合は小数で返る。
getAnimal
-
$animal = $dt->getAnimal; # 数値 0-11 を返す
この年の十二支を返す。0: 子, 1: 丑, ... 11: 亥
getAllHolidays
-
$hash = $dt->getAllHolidays;
この年にある日本の祝祭日を返す。返される値は、キーが MM-DD 形式の日付、 値が祝祭日名のハッシュである。
isHoliday
-
$bool = $dt->isHoliday($type);
この日が特定の日であれば 1 を、そうでなければ undef を返す。
特定の日とは以下の通り。
$typeが0の場合、土日及び日本の祝祭日。
$typeが1の場合、日及び日本の祝祭日。
$typeが2の場合、日本の祝祭日。
デフォルトは0。
getHolidayName
-
$str = $dt->getHolidayName;
この日が祝祭日であればその名前を、そうでなければ undef を返す。
isLeapYear
-
この年がうるう年であれば 1 を、そうでなければ undef を返す。
getCalendar
-
$array = $dt->getCalendar;
この月の日数分の DateTime オブジェクトが入った配列を返す。
getCalendarMatrix
-
$matrix = $dt->getCalendarMatrix(\$option);
この月のカレンダーを二次元配列で返す。 引数は次の通り:
type
-
'normal' または 'fixed' の2種類。fixed にすると行数が固定になる。
begin
-
'sun' または 'mon' の2種類。sun なら週が日曜から始まり、mon なら月曜。 デフォルトは sun 。
戻り値はカレンダーの一行分の DateTime オブジェクトの配列を1ヶ月分格納した配列。
spanSecond
-
$seconds = $dt->spanSecond($dt2); $seconds = $dt->spanSecond($dt1,$dt2);
引数との秒数の差を計算し、結果を整数で返す。 引数が2つ指定された場合は、引数同士の差を計算する。
spanは、実際の期間を、指定された単位で計算する。 spanDay で1日が返った場合は、2つの日付の間に24時間の間隔があることを示す。
spanMonth / Year の場合、それ以下の日部分の大小や年部分の大小を比較して、マイナス1すべきか判断する。 秒数を平均的な1月の長さや1年の長さで割って求めているわけではない。(年齢計算等に利用できる)
例:spanMonthの場合(2006年1月1日00時00分00秒と2005年12月31日00時00分00秒の場合、0が返る)
引数が DateTime オブジェクトだった場合はそのオブジェクトと比較し、 それ以外の場合は引数をそのまま $TL->newDateTime に渡して生成した オブジェクトと比較する。
返される値は ($dt) - ($dt2) もしくは、($dt1) - ($dt2)であり、引数が過去ならば結果は負になる。
spanMinute
spanHour
spanDay
spanMonth
spanYear
-
spanSecond と同様。
minusSecond
-
$seconds = $dt->minusSecond($dt2); $seconds = $dt->minusSecond($dt1,$dt2);
引数との秒数の差を計算し、結果を整数で返す。 引数が2つ指定された場合は、引数同士の差を計算する。
minusは、指定された単位部分の差を計算する。 minusDayであれば、時・分・秒の部分を無視し、 年月日のみで差を計算し、その差が何日分かを返す。
例:minsMonthの場合(2006年1月1日と2005年12月31日の場合、1が返る)
引数が DateTime オブジェク トだった場合はそのオブジェクトと比較し、それ以外の場合は引数をそのまま $TL->newDateTime に渡して生成したオブジェクトと比較する。
返される値は ($dt) - ($dt2) もしくは、($dt1) - ($dt2)であり、引数が過去ならば結果は負になる。
minusMinute
minusHour
minusDay
minusMonth
minusYear
-
minusSecond と同様。
addSecond
-
$dt->addSecond($sec);
$sec 秒後の時刻にする。
addMinute
addHour
addDay
-
addSecond と同様。
addMonth
-
addSecond と同様だが、もし変更前の日が変更後の年/月に存在しないもので あったら、日はその月の最後の日に変更される。
addYear
-
addMonth と同様。
addBusinessDay
-
$dt->addBusinessDay($day,$type);
$day 営業日後にする。 お盆や年末年始などは考慮しない。
例としては、12月31日で、$dayに1を指定した場合、翌年の1月2日になる。 (2日が振替休日の場合、3日になる)
休業日は$typeで決定する。
$typeが0の場合、土日及び日本の祝祭日。
$typeが1の場合、日及び日本の祝祭日。
$typeが2の場合、日本の祝祭日。
を休業日として営業日を判定する。
デフォルトは0。
nextDay
-
次の日にする。
prevDay
-
前の日にする。
firstDay
-
その月の最初の日にする。
lastDay
-
その月の最後の日にする。
toStr
-
$str = $dt->toStr('mysql'); # YYYY-MM-DD HH:MM:SS の形式で返す。 $str = $dt->toStr('rfc822'); # rfc822 形式で返す。 $str = $dt->toStr('rfc850'); # rfc850 形式で返す。 $str = $dt->toStr('w3c'); # W3c Date and Time の形式で返す。 $str = $dt->toStr; # mysql と同じ。
文字列で表した日付と時刻を返す。
strFormat
-
$str = $dt->strFormat('%Y 年 %m 月 %d 日 (%J) %H 時 %M 分');
指定されたフォーマットに従って文字列化したものを返す。
%a
-
短縮された曜日の名前 (Sun - Sat)
%A
-
完全な曜日の名前 (Sunday - Saturday)
%J
-
日本語での曜日の名前 (日 - 土)
%b
-
短縮された月の名前 (Jan - Dec)
%B
-
完全な月の名前 (January - December)
%_B
-
日本語での月の名前 (睦月 - 師走)
%d
-
日を2桁で表現 (01 - 31)
%_d
-
日 (1 - 31)
%m
-
月を2桁で表現 (01-12)
%_m
-
月 (1-12)
%w
-
曜日を10進数で表現。0 - 6 で、日曜が 0 、月曜が 1 。
%y
-
年を下2桁で表現 (00 - 99)
%Y
-
年を4桁で表現
%_Y
-
年を和暦で表現。 (平成11年 等)
和暦の定義されていない範囲では空文字列。
%H
-
時を24時間表記で2桁で表現 (00-23)
%_H
-
時を24時間表記で表現 (0-23)
%I
-
時を12時間表記で2桁で表現 (00-11)
%_I
-
時を12時間表記で表現 (0-11)
%P
-
時刻が午前なら 'a.m.', 午後なら 'p.m.' に置換する。 24時間表記での0時0分は午前とし、12時0分は午後とする。
このパターンが parseFormat で使われる時は、大文字と小文字は無視され、 ピリオドの有無も無視される。例えば 'AM', 'A.M.', 'a.M' はいずれも午前 としてパースされる。
%_P
-
時刻が午前なら '午前', 午後なら '午後' に置換する。
%M
-
分を2桁で表現 (00-59)
%_M
-
分 (0-59)
%S
-
秒を2桁で表現 (00-59)
%_S
-
秒 (0-59)
%E
-
十二支を表す文字 (子 - 亥)
%z
-
RFC 822 形式に於けるタイムゾーン。JSTの場合は '+0900' になる。
%_z
-
W3C Date and Time 形式に於けるタイムゾーン。JSTの場合は '+09:00' になる。
%Z
-
タイムゾーンを表す名称。存在しない場合は空文字列になる。
%T
-
'%H:%M:%S' のフォーマットで返される文字列
%%
-
'%' という文字
parseFormat
-
$dt->parseFormat('%Y %d %m', '2006 01 13');
指定されたフォーマットを用いて日付と時刻の文字列をパースする。フォーマッ ト文字は strFormat のものと同一。フォーマット文字列から年を得 る事が出来ない場合や、パースに失敗した場合は、die する。
また、常に空白または0による桁揃えの有無、全角半角は無視して解析する。
12時間表記の時間である %I と %_I と、午前または午後を表す %P と %_P は、 用いられる際には必ず両方用いられなければならない。いずれか片方だけでは 正確な時刻が判らない為。
SEE ALSO
AUTHOR INFORMATION
Copyright 2006 YMIRLINK Inc. All Rights Reserved.
This framework is free software; you can redistribute it and/or modify it under the same terms as Perl itself
このフレームワークはフリーソフトウェアです。あなたは Perl と同じライセンスの 元で再配布及び変更を行うことが出来ます。
Address bug reports and comments to: tl@tripletail.jp
HP : http://tripletail.jp/