Zend_Date-Overview.xml 56 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17986 -->
  4. <sect1 id="zend.date.overview">
  5. <title>Zend_Date API の概要</title>
  6. <para>
  7. <classname>Zend_Date</classname> の <acronym>API</acronym> はシンプルで統一性がありますが、
  8. 非常に柔軟で強力な設計になっており、
  9. さまざまな操作や演算ができます。
  10. </para>
  11. <sect2 id="zend.date.options">
  12. <title>Zend_Date のオプション</title>
  13. <sect3 id="zend.date.options.formattype">
  14. <title>日付の書式の型の選択</title>
  15. <para>
  16. いくつかのメソッドでは、<acronym>PHP</acronym> の <methodname>date()</methodname> 関数と似た形式の日付書式文字列を使用します。
  17. <acronym>PHP</acronym> の日付書式指定子のほうが <acronym>ISO</acronym> 書式指定子よりなじみがあるという場合は、
  18. <methodname>Zend_Date::setOptions(array('format_type' => 'php'))</methodname>
  19. とできます。こうすると、<varname>$format</varname>
  20. パラメータを持つすべての関数で <acronym>PHP</acronym> の日付書式指定子が使用できるようになります。
  21. <methodname>Zend_Date::setOptions(array('format_type' => 'iso'))</methodname>
  22. とすると、デフォルトのモードに戻ります。このモードは、
  23. <acronym>ISO</acronym> 日付書式トークンのみをサポートするものです。
  24. サポートする書式コードの一覧は、
  25. <link linkend="zend.date.constants.phpformats" /> を参照ください。
  26. </para>
  27. </sect3>
  28. <sect3 id="zend.date.options.fixdst">
  29. <title>夏時間と月</title>
  30. <para>
  31. 日付を処理する際には、夏時間の適用前後をまたがってしまうこともあります。
  32. 通常は、そのような場合は結果が一時間増えたり減ったりします。
  33. たとえば、夏時間の適用前の日付に何ヶ月か追加してその結果が夏時間適用後になった場合、
  34. 結果の日付は一時間ずれます。月末や月初の深夜 0 時のような境界上で、
  35. それをまたがった月の加算を行うと、結果から 1 時間引かれることで
  36. 前月末日の日付になってしまい "off by 1" エラーが発生します。
  37. このような状況になることを避けるためには、夏時間の変更を無視するためのオプション
  38. <code>fix_dst</code> を使用します。夏時間/冬時間の境界をまたぐ際に、
  39. 通常は 1 時間分足したり引いたりします。
  40. たとえば、春の夏時間適用日をまたがる日付計算の結果は、
  41. 時刻部分が 00:00:00 のままの場合は予期したものより 1 日少なくなります。というのも、
  42. <classname>Zend_Date</classname> は日付部分ではなくタイムスタンプに基づいて計算を行うからです。
  43. タイムスタンプが 1 時間少なくなるので、日付も予期したものより 1 日少なくなってしまいます。
  44. これを避けるためにはオプション <code>fix_dst</code> を使用します。
  45. このオプションのデフォルトは <constant>TRUE</constant> で、この場合は夏時間が
  46. "月" の計算 (<methodname>addMonth()</methodname>、
  47. <methodname>subMonth()</methodname>) に影響を与えなくなります。
  48. <methodname>Zend_Date::setOptions(array('fix_dst' => false))</methodname> とすると、
  49. 夏時間にあわせた時間の加減算を "月" の計算時にも適用します。
  50. </para>
  51. <para>
  52. <emphasis><classname>Zend_Date</classname>
  53. インスタンスの実際のタイムゾーンが <acronym>UTC</acronym> あるいは <acronym>GMT</acronym> の場合、
  54. オプション <code>'fix_dst'</code> は用いられません</emphasis>。
  55. これらのタイムゾーンには DST は適用されないからです。
  56. このインスタンスのタイムゾーンを <acronym>UTC</acronym> あるいは <acronym>GMT</acronym> 以外のものに変更すると、
  57. その前に設定されていた 'fix_dst' オプションの値を
  58. "月" の計算時に適用します。
  59. </para>
  60. </sect3>
  61. <sect3 id="zend.date.options.extendmonth">
  62. <title>月の計算</title>
  63. <para>
  64. ある日付に対して月を足したり引いたりすると、
  65. もとの日付が月の最後のほうだった場合に予期せぬ結果となることがあります。
  66. たとえば「1月31日」に一ヶ月足すことを考えてみましょう。
  67. <acronym>SQL</acronym> に慣れている人なら、この結果は「2月28日」になるものと思われるでしょう。
  68. 一方、Excel や OpenOffice を使っている人は、この結果が「3月3日」
  69. になるものと考えるのではないでしょうか。
  70. この問題は、計算結果の月の日数が元の日付の月の日数より少ない場合に起こりえます。
  71. Zend Framework の開発者向けには、どちらの方式かを選択できるようにしました。
  72. <code>extend_month</code> オプションを <constant>FALSE</constant> にすると
  73. <acronym>SQL</acronym> 風の挙動になり、<constant>TRUE</constant> にすると表計算ソフト風の挙動になります。
  74. <code>extend_month</code> のデフォルトは <constant>FALSE</constant> なので、
  75. <classname>Zend_Date</classname> は <acronym>SQL</acronym> 互換の計算をします。
  76. デフォルトでは、<classname>Zend_Date</classname> は月の計算をする際に
  77. (必要に応じて) 日を切り詰めます。計算した結果に該当する日がその月に存在しなかった場合に、
  78. 翌月にまたがることはありません。
  79. <methodname>Zend_Date::setOptions(array('extend_month' => true))</methodname>
  80. とすると、表計算ソフトと同様の方式で計算することになります。
  81. </para>
  82. </sect3>
  83. <sect3 id="zend.date.options.cache">
  84. <title>日付の地域化や正規化の、Zend_Cache による高速化</title>
  85. <para>
  86. <classname>Zend_Date</classname> を高速に動作させるには <classname>Zend_Cache</classname>
  87. アダプタを使用します。これを使用すると、地域化したデータを扱う際の
  88. <classname>Zend_Date</classname> のすべてのメソッドが高速化します。
  89. たとえば、定数 <constant>Zend_Date::DATE</constant> や
  90. <constant>Zend_Date::TIME</constant> を扱うメソッドは、すべてこの影響を受けます。
  91. <classname>Zend_Cache</classname> アダプタを <classname>Zend_Date</classname> に設定するには、
  92. <methodname>Zend_Date::setOptions(array('cache' => $adapter))</methodname>
  93. とするだけです。
  94. </para>
  95. </sect3>
  96. <sect3 id="zend.date.options.timesync">
  97. <title>Zend_TimeSync による同期したタイムスタンプの取得</title>
  98. <para>
  99. 通常は、サーバやコンピュータの時刻はそれぞれ異なります。
  100. <classname>Zend_Date</classname> は、この問題を
  101. <classname>Zend_TimeSync</classname> で解決できます。
  102. タイムサーバを <methodname>Zend_Date::setOptions(array('timesync' => $timeserver))</methodname>
  103. で設定すると、すべての <classname>Zend_Date</classname> インスタンスについて、
  104. そのタイムスタンプと実際のタイムスタンプを間のオフセットを設定します。
  105. このオプションを使用しても、既存のインスタンスのタイムスタンプは変わりません。
  106. そこで、これを用いる場合は起動ファイルで設定することをおすすめします。
  107. </para>
  108. </sect3>
  109. </sect2>
  110. <sect2 id="zend.date.values">
  111. <title>日付の値の操作</title>
  112. <para>
  113. <classname>Zend_Date</classname> オブジェクトの作成によって入力が正規化されると、
  114. このオブジェクトはタイムゾーンに関連付けられます。しかし、内部的な形式としては通常の
  115. <ulink url="http://en.wikipedia.org/wiki/Unix_Time">UNIX タイムスタンプ</ulink>を使用します。
  116. 各地域固有の方式で日付を表示するには、まずタイムゾーンを知る必要があります。
  117. デフォルトのタイムゾーンは常に <acronym>GMT</acronym>/UTC です。オブジェクトのタイムゾーンを調べるには
  118. <methodname>getTimeZone()</methodname> を使用します。オブジェクトのタイムゾーンを変更するには
  119. <methodname>setTimeZone()</methodname> を使用します。
  120. これらのオブジェクトに対するすべての操作は、このタイムゾーンを想定して行われます。
  121. </para>
  122. <para>
  123. 異なるタイムゾーンの日付オブジェクトを混在させないよう注意しましょう。
  124. タイムスタンプにのみかかわる操作しかしないのならよいのですが、
  125. それ以外の場合には期待通りの結果が得られなくなるでしょう。
  126. 異なるタイムゾーンの <classname>Zend_Date</classname> に対する操作は、
  127. たいていの場合はうまく動作します。というのも <classname>Zend_Date</classname>
  128. のインスタンスを作成する際に、値が UNIX タイムスタンプに正規化されるからです。
  129. </para>
  130. <para>
  131. ほとんどのメソッドで、引数 <varname>$part</varname> に定数を指定できます。
  132. これにより、日付のどの部分を選択するかを指定します。この定数は、
  133. たとえば <constant>Zend_Date::HOUR</constant> のようになります。
  134. これらの定数は、以下のすべての関数で使用できます。使用可能なすべての定数の一覧は
  135. <link linkend="zend.date.constants.list" /> にあります。
  136. <varname>$part</varname> を省略した場合は、<constant>Zend_Date::TIMESTAMP</constant>
  137. が指定されたものとみなします。また、ユーザ定義の書式を
  138. <varname>$part</varname> で使用することもできます。ここには、
  139. <link linkend="zend.locale.date.normalize"><methodname>Zend_Locale_Format::getDate()</methodname>
  140. </link>
  141. と同様のコードを使用します。
  142. 日付オブジェクトが明らかに無効な値を用いて作成された場合 (たとえば月が 12 より大きいなど) は、
  143. <classname>Zend_Date</classname> は例外をスローします。ただし、特定の日付フォーマットが指定されている場合、
  144. つまり <varname>$part</varname> が <constant>NULL</constant> あるいは <constant>Zend_Date::DATES</constant> ("あいまいな" フォーマット)
  145. のいずれかである場合は別です。
  146. </para>
  147. <example id="zend.date.values.example-1">
  148. <title>ユーザ定義の入力日付書式</title>
  149. <programlisting language="php"><![CDATA[
  150. $date1 = new Zend_Date('Feb 31, 2007', null, 'en_US');
  151. echo $date1, "\n"; // 出力は "Mar 3, 2007 12:00:00 AM" となります
  152. $date2 = new Zend_Date('Feb 31, 2007', Zend_Date::DATES, 'en_US');
  153. echo $date2, "\n"; // 出力は "Mar 3, 2007 12:00:00 AM" となります
  154. // 指定したフォーマットで解釈するように強制します
  155. $date3 = new Zend_Date('Feb 31, 2007', 'MM.dd.yyyy');
  156. echo $date3, "\n"; // 出力は "Mar 3, 2007 12:00:00 AM" となります
  157. ]]></programlisting>
  158. </example>
  159. <para>
  160. オプションのパラメータ <varname>$locale</varname> を指定すると、
  161. その <varname>$locale</varname> をもとに <varname>$date</varname> オペランドを解決します。
  162. つまり、日付文字列に含まれる月名や曜日名などを、そのロケールにあわせて適切に解釈します
  163. (<code>
  164. <link linkend="zend.locale.date.normalize">Zend_Locale_Format::getDate()</link>
  165. </code> を参照ください)。
  166. 各地域固有の形式の文字列で <varname>$date</varname> オペランドが指定された際に
  167. 自動で正規化が行われるのは、<varname>$part</varname> が
  168. 定数 <constant>Zend_Date::DATE*</constant> あるいは <constant>Zend_Date::TIME*</constant> のいずれかであるときです。
  169. <varname>$date</varname> が日付を含む文字列の場合は、
  170. 月名や曜日名をパースする際に使用する言語はロケールをもとに決定します。
  171. 入力パラメータ <varname>$date</varname> が指定されなかった場合は、
  172. <varname>$locale</varname> パラメータの内容をもとにして地域化した結果
  173. (日付書式を文字列で表したもの) を出力します。
  174. 入力パラメータ <varname>$date</varname> に具体的な型が指定されている場合もあります
  175. (たとえば <methodname>addHour()</methodname> では <varname>$hour</varname> です)。
  176. このような場合でも、引数として <classname>Zend_Date</classname>
  177. オブジェクトを使用できることに注意しましょう。
  178. <varname>$locale</varname> を指定しなかった場合は、
  179. 現在のオブジェクトのロケールを使用して
  180. <varname>$date</varname> を解釈します。あるいは出力用書式を選択します。
  181. </para>
  182. <para>
  183. Zend Framework 1.7.0 以降では、<classname>Zend_Date</classname>
  184. はアプリケーション単位でのロケールの使用にも対応します。
  185. そのためには、<classname>Zend_Locale</classname>
  186. のインスタンスを以下のようにレジストリに登録します。
  187. このようにすれば、同じロケールを何度も使用したいときに
  188. 各インスタンスで毎回ロケールを設定する手間を省けます。
  189. </para>
  190. <programlisting language="php"><![CDATA[
  191. // 起動ファイルで
  192. $locale = new Zend_Locale('de_AT');
  193. Zend_Registry::set('Zend_Locale', $locale);
  194. // アプリケーションのどこかで
  195. $date = new Zend_Date('31.Feb.2007');
  196. ]]></programlisting>
  197. </sect2>
  198. <sect2 id="id.date.basic">
  199. <title>多くの日付要素で共通に使用できる、Zend_Date の基本操作</title>
  200. <para>
  201. メソッド <methodname>add()</methodname>, <methodname>sub()</methodname>,
  202. <methodname>compare()</methodname>, <methodname>get()</methodname> および
  203. <methodname>set()</methodname>
  204. は、日付全般に対して使用できます。それぞれのメソッドは、
  205. そのインスタンスが保持する日付の値を操作します。
  206. これらのメソッドのうち、<methodname>get()</methodname>
  207. 以外ではすべて <varname>$date</varname> オペランドが必要となります。
  208. ここには <classname>Zend_Date</classname> のインスタンスか
  209. 数値文字列、あるいは整数値を指定します。
  210. これらのメソッドで <varname>$date</varname> にオブジェクト以外を指定した場合、
  211. それはタイムスタンプであるとみなされます。
  212. しかし、<varname>$part</varname> オペランドを使用すると、
  213. ふたつの日付データが日付のどの部分を表すものなのかを指定できます。
  214. たとえば "年"、"分" などが指定できます。それだけではなく、
  215. "December 31, 2007 23:59:59" のような長い形式の文字列も
  216. <varname>$date</varname> に指定できます。
  217. <methodname>compare()</methodname> および <methodname>get()</methodname>
  218. 以外のメソッドは、処理の結果としてオブジェクト内の日付が変更されます。
  219. </para>
  220. <example id="zend.date.basic.example-1">
  221. <title>日付要素の操作</title>
  222. <programlisting language="php"><![CDATA[
  223. $date = new Zend_Date(); // $date のタイムスタンプは time() の返す値と等しくなります
  224. // $date に 12 時間足します
  225. $date->add('12', Zend_Date::HOUR);
  226. print $date;
  227. ]]></programlisting>
  228. </example>
  229. <para>
  230. 基本的な操作について、一般的な日付要素と組み合わせて使用する際に
  231. 便利なメソッドが用意されています。
  232. これらのメソッドを使用すると、上で説明したメソッドのように
  233. <link linkend="zend.date.constants.list">日付要素の定数</link>
  234. をいちいちタイプする必要がなくなります。
  235. 好都合なことに、これらのメソッドの名前は
  236. プレフィックス (基本操作の名前) とサフィックス (日付要素の名前)
  237. を組み合わせた形式、たとえば <methodname>addYear()</methodname>
  238. のようになっています。以下の一覧における、すべての
  239. "日付要素" と "基本操作" の組み合わせが存在します。
  240. たとえば "add" は、各要素について
  241. <methodname>addDay()</methodname> や <methodname>addYear()</methodname>
  242. などといったメソッドが存在します。
  243. </para>
  244. <para>
  245. これらの便利なメソッドの機能は、基本操作メソッドと同等です。
  246. しかし、<varname>$date</varname> オペランドに文字列や整数値を使用する場合は、
  247. メソッド名のサフィックスが指す日付要素以外を指定することはできません。
  248. つまり、<varname>$date</varname> が文字列あるいは整数値の場合は、
  249. <varname>$date</varname> オペランドの単位が
  250. メソッド名によって ("Year" や "Minute" などに) 決まるということです。
  251. </para>
  252. <sect3 id="id.date.basic.parts">
  253. <title>日付要素の一覧</title>
  254. <table id="id.date.basic.parts.table">
  255. <title>日付要素</title>
  256. <tgroup cols="2">
  257. <thead>
  258. <row>
  259. <entry>日付要素</entry>
  260. <entry>説明</entry>
  261. </row>
  262. </thead>
  263. <tbody>
  264. <row>
  265. <entry>
  266. <ulink url="http://en.wikipedia.org/wiki/Unix_Time">Timestamp (タイムスタンプ)</ulink>
  267. </entry>
  268. <entry>
  269. UNIX タイムスタンプ。January 1st, 1970 00:00:00 <acronym>GMT</acronym>/UTC
  270. からの経過秒数です。
  271. </entry>
  272. </row>
  273. <row>
  274. <entry>
  275. <ulink url="http://ja.wikipedia.org/wiki/%E3%82%B0%E3%83%AC%E3%82%B4%E3%83%AA%E3%82%AA%E6%9A%A6">Year (年)</ulink>
  276. </entry>
  277. <entry>グレゴリオ暦の年 (例: 2006)。</entry>
  278. </row>
  279. <row>
  280. <entry>
  281. <ulink url="http://ja.wikipedia.org/wiki/%E6%9C%88_%28%E6%9A%A6%29#.E5.A4.AA.E9.99.BD.E6.9A.A6">Month (月)</ulink>
  282. </entry>
  283. <entry>グレゴリオ暦の月 (1-12、各地域固有の名前もサポートしています)。</entry>
  284. </row>
  285. <row>
  286. <entry>
  287. <ulink url="http://en.wikipedia.org/wiki/24-hour_clock">24 hour clock (24 時間の時間)</ulink>
  288. </entry>
  289. <entry>その日の時間 (0-23)。これは、その日がはじまってからの経過時間数を表します。</entry>
  290. </row>
  291. <row>
  292. <entry>
  293. <ulink url="http://ja.wikipedia.org/wiki/%E5%88%86">minute (分)</ulink>
  294. </entry>
  295. <entry>時間内の分 (0-59)。これは、その時間がはじまってからの経過分数を表します。</entry>
  296. </row>
  297. <row>
  298. <entry>
  299. <ulink url="http://ja.wikipedia.org/wiki/%E7%A7%92">Second (秒)</ulink>
  300. </entry>
  301. <entry>分内の秒 (0-59)。これは、その分が始まってからの経過秒数を表します。</entry>
  302. </row>
  303. <row>
  304. <entry>
  305. <ulink url="http://en.wikipedia.org/wiki/Millisecond">millisecond (ミリ秒)</ulink>
  306. </entry>
  307. <entry>
  308. ミリ秒 (0-999)。これは、千分の一秒を表します。
  309. <classname>Zend_Date</classname> では、秒未満の単位を扱うために
  310. 二つのメソッドを用意しています。デフォルトでは、
  311. <classname>Zend_Date</classname> のインスタンスはミリ秒単位の精度を使用します。
  312. これは <methodname>getFractionalPrecision()</methodname> を使用して取得します。
  313. 精度を変更するには <methodname>setFractionalPrecision($precision)</methodname>
  314. を使用します。しかし、精度は事実上ミリ秒までに制限されます。
  315. というのも、<classname>Zend_Date</classname> は <code>
  316. <ulink url="http://php.net/microtime">microtime()</ulink></code>
  317. を使用しているからです。
  318. </entry>
  319. </row>
  320. <row>
  321. <entry>
  322. <ulink url="http://ja.wikipedia.org/wiki/%E6%97%A5">Day (日)</ulink>
  323. </entry>
  324. <entry>
  325. <constant>Zend_Date::DAY_SHORT</constant> は <varname>$date</varname>
  326. から抽出します。これは、<varname>$date</varname> オペランドが
  327. <classname>Zend_Date</classname> のインスタンスであるか、
  328. あるいは数値文字列である場合に行われます。
  329. それ以外の場合は、以下の定数によって指定した規約に基づいて抽出します。
  330. <constant>Zend_Date::WEEKDAY_NARROW</constant>、<constant>Zend_Date::WEEKDAY_NAME</constant>、
  331. <constant>Zend_Date::WEEKDAY_SHORT</constant>、
  332. <constant>Zend_Date::WEEKDAY</constant> (グレゴリオ暦とみなして処理します)。
  333. </entry>
  334. </row>
  335. <row>
  336. <entry>
  337. <ulink url="http://ja.wikipedia.org/wiki/%E9%80%B1">Week (週)</ulink>
  338. </entry>
  339. <entry>
  340. <constant>Zend_Date::WEEK</constant> は <varname>$date</varname>
  341. から抽出します。これは、<varname>$date</varname> オペランドが
  342. <classname>Zend_Date</classname> のインスタンスであるか、
  343. あるいは数値文字列である場合に行われます。
  344. それ以外の場合は例外が発生します (グレゴリオ暦とみなして処理します)。
  345. </entry>
  346. </row>
  347. <row>
  348. <entry>Date (日)</entry>
  349. <entry>
  350. <constant>Zend_Date::DAY_MEDIUM</constant> は <varname>$date</varname>
  351. から抽出します。これは、<varname>$date</varname> オペランドが
  352. <classname>Zend_Date</classname> のインスタンスである場合に行われます。
  353. それ以外の場合は、文字列 <varname>$date</varname>
  354. を正規化して Zend_Date::DATE_MEDIUM 形式の日付にしようとします。
  355. <constant>Zend_Date::DAY_MEDIUM</constant> の書式は、
  356. そのオブジェクトのロケールに依存します。
  357. </entry>
  358. </row>
  359. <row>
  360. <entry>Weekday (曜日)</entry>
  361. <entry>
  362. 曜日は、0 (日曜日) から 6 (土曜日) までの数字で表されます。
  363. <constant>Zend_Date::WEEKDAY_DIGIT</constant> は <varname>$date</varname>
  364. から抽出します。これは、<varname>$date</varname> オペランドが
  365. <classname>Zend_Date</classname> のインスタンスであるか、
  366. あるいは数値文字列である場合に行われます。
  367. それ以外の場合は、以下の定数によって指定した規約に基づいて抽出します。
  368. <constant>Zend_Date::WEEKDAY_NARROW</constant>、<constant>Zend_Date::WEEKDAY_NAME</constant>、
  369. <constant>Zend_Date::WEEKDAY_SHORT</constant>、
  370. <constant>Zend_Date::WEEKDAY</constant> (グレゴリオ暦とみなして処理します)。
  371. </entry>
  372. </row>
  373. <row>
  374. <entry>DayOfYear (年内の日数)</entry>
  375. <entry>
  376. <classname>Zend_Date</classname> では、これは年初からの経過日数
  377. (0-365) を表します。これまでの他の単位と同様、
  378. 端数は切り捨てられます (グレゴリオ暦とみなして処理します)。
  379. </entry>
  380. </row>
  381. <row>
  382. <entry>
  383. <ulink url="http://www.faqs.org/rfcs/rfc822.html">Arpa</ulink>
  384. </entry>
  385. <entry>
  386. Arpa 日付 (つまり <acronym>RFC</acronym> 822 形式の日付) をサポートしています。
  387. 出力形式は、"GMT" あるいは "地方時 + 時差" 形式になります
  388. (<acronym>RFC</acronym> 822 の section 5 を参照ください)。
  389. <acronym>PHP</acronym> 5.2.2 より前のバージョンでは、定数 DATE_RFC822 を
  390. <acronym>PHP</acronym> の日付関数で使用したときに
  391. <ulink url="http://bugs.php.net/bug.php?id=40308">おかしな結果</ulink>
  392. となる場合がありました。<classname>Zend_Date</classname> は、正しい結果を返します。
  393. 例: <code>Mon, 31 Dec 06 23:59:59 GMT</code>
  394. </entry>
  395. </row>
  396. <row>
  397. <entry>
  398. <ulink url="http://ja.wikipedia.org/wiki/ISO_8601">Iso</ulink>
  399. </entry>
  400. <entry>
  401. 出力形式として、完全な <acronym>ISO</acronym> 8601 日付のみをサポートしています。
  402. 例: <code>2009-02-14T00:31:30+01:00</code>
  403. </entry>
  404. </row>
  405. </tbody>
  406. </tgroup>
  407. </table>
  408. </sect3>
  409. <sect3 id="id.date.basic.operations">
  410. <title>日付操作の一覧</title>
  411. <para>
  412. 便利なメソッド群ではなく以下の基本操作を使用する場合には、
  413. <link linkend="zend.date.constants.list">適切な定数</link>
  414. を <varname>$part</varname> パラメータで指定します。
  415. </para>
  416. <table id="id.date.basic.operations.table">
  417. <title>基本操作</title>
  418. <tgroup cols="2">
  419. <thead>
  420. <row>
  421. <entry>基本操作</entry>
  422. <entry>説明</entry>
  423. </row>
  424. </thead>
  425. <tbody>
  426. <row>
  427. <entry><methodname>get()</methodname></entry>
  428. <entry>
  429. <para>
  430. <emphasis>get($part = null, $locale = null)</emphasis>
  431. </para>
  432. <para>
  433. <methodname>get($part)</methodname> を使用して、このオブジェクトの日付の
  434. <varname>$part</varname> の部分を取得します。
  435. 結果は、<varname>$locale</varname>
  436. にもとづいて地域化された書式の文字列か整数値となります。
  437. BCMath 拡張モジュールを使用している場合は、
  438. 大きな値の場合に整数ではなく数値文字列が返されるかもしれません。
  439. <emphasis>注意:</emphasis> <methodname>get()</methodname>
  440. とは異なり、その他の get*() 系のメソッドは
  441. <classname>Zend_Date</classname> のインスタンスのみを返します。
  442. その中身は、選択された時刻/日付となります。
  443. </para>
  444. </entry>
  445. </row>
  446. <row>
  447. <entry><methodname>set()</methodname></entry>
  448. <entry>
  449. <para>
  450. <emphasis>set($date, $part = null, $locale = null)</emphasis>
  451. </para>
  452. <para>
  453. ロケール <varname>$locale</varname> の入力データ <varname>$date</varname>
  454. から、 <varname>$part</varname> に対応する部分の値を
  455. 現在のオブジェクトに設定します。
  456. </para>
  457. </entry>
  458. </row>
  459. <row>
  460. <entry><methodname>add()</methodname></entry>
  461. <entry>
  462. <para>
  463. <emphasis>add($date, $part = null, $locale = null)</emphasis>
  464. </para>
  465. <para>
  466. ロケール <varname>$locale</varname> の入力データ <varname>$date</varname>
  467. から、 <varname>$part</varname> に対応する部分の値を
  468. 現在のオブジェクトに加えます。
  469. </para>
  470. </entry>
  471. </row>
  472. <row>
  473. <entry><methodname>sub()</methodname></entry>
  474. <entry>
  475. <para>
  476. <emphasis>sub($date, $part = null, $locale = null)</emphasis>
  477. </para>
  478. <para>
  479. ロケール <varname>$locale</varname> の入力データ <varname>$date</varname>
  480. から、 <varname>$part</varname> に対応する部分の値を
  481. 現在のオブジェクトから引きます。
  482. </para>
  483. </entry>
  484. </row>
  485. <row>
  486. <entry><methodname>copyPart()</methodname></entry>
  487. <entry>
  488. <para>
  489. <emphasis>copyPart($part, $locale = null)</emphasis>
  490. </para>
  491. <para>
  492. オブジェクトの複製を返します。もとのオブジェクトの日付のうち
  493. <varname>$part</varname> の部分のみがコピーされます。
  494. 複製のロケールは、<varname>$locale</varname> で任意のものに指定できます。
  495. </para>
  496. </entry>
  497. </row>
  498. <row>
  499. <entry><methodname>compare()</methodname></entry>
  500. <entry>
  501. <para>
  502. <emphasis>compare($date, $part = null, $locale = null)</emphasis>
  503. </para>
  504. <para>
  505. <varname>$date</varname> の <varname>$part</varname> 部分を
  506. このオブジェクトのタイムスタンプと比較します。等しい場合は 0、
  507. このオブジェクトの値のほうが $date の内容より新しい場合に 1、
  508. それ以外の場合に -1 を返します。
  509. </para>
  510. </entry>
  511. </row>
  512. </tbody>
  513. </tgroup>
  514. </table>
  515. </sect3>
  516. </sect2>
  517. <sect2 id="zend.date.others.comparison">
  518. <title>日付の比較</title>
  519. <para>
  520. 以下の基本操作については、
  521. <link linkend="zend.date.overview" />
  522. の一覧にある各日付要素に特化した便利なメソッドは存在しません。
  523. </para>
  524. <table id="zend.date.others.comparison.table">
  525. <title>日付の比較用メソッド</title>
  526. <tgroup cols="2">
  527. <thead>
  528. <row>
  529. <entry>メソッド</entry>
  530. <entry>説明</entry>
  531. </row>
  532. </thead>
  533. <tbody>
  534. <row>
  535. <entry><methodname>equals()</methodname></entry>
  536. <entry>
  537. <para>
  538. <emphasis>equals($date, $part = null, $locale = null)</emphasis>
  539. </para>
  540. <para>
  541. ロケール <varname>$locale</varname> で格納されている日付 <varname>$date</varname>
  542. の要素 <varname>$part</varname> がこのオブジェクトの日付要素と等しい場合に <constant>TRUE</constant>、
  543. それ以外の場合に <constant>FALSE</constant> を返します。
  544. </para>
  545. </entry>
  546. </row>
  547. <row>
  548. <entry><methodname>isEarlier()</methodname></entry>
  549. <entry>
  550. <para>
  551. <emphasis>isEarlier($date, $part = null, $locale = null)</emphasis>
  552. </para>
  553. <para>
  554. このオブジェクトの日付要素 <varname>$part</varname> が、
  555. ロケール <varname>$locale</varname> で格納されている日付 <varname>$date</varname>
  556. の要素 <varname>$part</varname> より前である場合に <constant>TRUE</constant> を返します。
  557. </para>
  558. </entry>
  559. </row>
  560. <row>
  561. <entry><methodname>isLater()</methodname></entry>
  562. <entry>
  563. <para>
  564. <emphasis>isLater($date, $part = null, $locale = null)</emphasis>
  565. </para>
  566. <para>
  567. このオブジェクトの日付要素 <varname>$part</varname> が、
  568. ロケール <varname>$locale</varname> で格納されている日付 <varname>$date</varname>
  569. の要素 <varname>$part</varname> より後である場合に <constant>TRUE</constant> を返します。
  570. </para>
  571. </entry>
  572. </row>
  573. <row>
  574. <entry><methodname>isToday()</methodname></entry>
  575. <entry>
  576. <para>
  577. <emphasis>isToday()</emphasis>
  578. </para>
  579. <para>
  580. 今日の年月日が、このオブジェクトの日付と一致するかどうかを調べます
  581. (このオブジェクトのタイムゾーンを用いて判断します)。
  582. </para>
  583. </entry>
  584. </row>
  585. <row>
  586. <entry><methodname>isTomorrow()</methodname></entry>
  587. <entry>
  588. <para>
  589. <emphasis>isTomorrow()</emphasis>
  590. </para>
  591. <para>
  592. 明日の年月日が、このオブジェクトの日付と一致するかどうかを調べます
  593. (このオブジェクトのタイムゾーンを用いて判断します)。
  594. </para>
  595. </entry>
  596. </row>
  597. <row>
  598. <entry><methodname>isYesterday()</methodname></entry>
  599. <entry>
  600. <para>
  601. <emphasis>isYesterday()</emphasis>
  602. </para>
  603. <para>
  604. 昨日の年月日が、このオブジェクトの日付と一致するかどうかを調べます
  605. (このオブジェクトのタイムゾーンを用いて判断します)。
  606. </para>
  607. </entry>
  608. </row>
  609. <row>
  610. <entry><methodname>isLeapYear()</methodname></entry>
  611. <entry>
  612. <para>
  613. <emphasis>isLeapYear()</emphasis>
  614. </para>
  615. <para>
  616. <methodname>isLeapYear()</methodname> を使用して、
  617. そのオブジェクトが閏年であるかどうかを調べます。あるいは
  618. <methodname>Zend_Date::checkLeapYear($year)</methodname> を使用すると、
  619. <varname>$year</varname>
  620. (文字列、整数値 あるいは <classname>Zend_Date</classname> のインスタンス)
  621. が閏年かどうかを知ることができます。
  622. </para>
  623. </entry>
  624. </row>
  625. <row>
  626. <entry><methodname>isDate()</methodname></entry>
  627. <entry>
  628. <para>
  629. <emphasis>isDate($date, $format = null, $locale = null)</emphasis>
  630. </para>
  631. <para>
  632. このメソッドは、指定した日付が本当に日付であるかどうかを調べ、
  633. すべてのチェックを通過したときに <constant>TRUE</constant> を返します。
  634. <acronym>PHP</acronym> の checkdate() 関数と似たような働きですが、各地域固有の月名にも対応しており、
  635. また checkdate() の対象範囲外の日付でも正しく判定できます。
  636. </para>
  637. </entry>
  638. </row>
  639. </tbody>
  640. </tgroup>
  641. </table>
  642. </sect2>
  643. <sect2 id="zend.date.others.gettingparts">
  644. <title>日付および日付要素の取得</title>
  645. <para>
  646. <classname>Zend_Date</classname> インスタンスに関する情報の取得をサポートするメソッド群について説明します。
  647. </para>
  648. <table id="zend.date.others.gettingparts.table">
  649. <title>日付出力用のメソッド</title>
  650. <tgroup cols="2">
  651. <thead>
  652. <row>
  653. <entry>メソッド</entry>
  654. <entry>説明</entry>
  655. </row>
  656. </thead>
  657. <tbody>
  658. <row>
  659. <entry><methodname>toString()</methodname></entry>
  660. <entry>
  661. <para>
  662. <emphasis>toString($format = null, $locale = null)</emphasis>
  663. </para>
  664. <para>
  665. 直接実行することもできますし、マジックメソッド <methodname>__toString()</methodname>
  666. から間接的にコールされることもあります。
  667. <methodname>toString()</methodname> メソッドは、自動的にオブジェクトの値の書式を設定します。
  668. この書式は、オブジェクトのロケールか、あるいはオプションで指定した
  669. <varname>$locale</varname> にもとづいて決まります。
  670. サポートする書式コードの一覧は、
  671. <link linkend="zend.date.constants.selfdefinedformats" />
  672. を参照ください。
  673. </para>
  674. </entry>
  675. </row>
  676. <row>
  677. <entry><methodname>toArray()</methodname></entry>
  678. <entry>
  679. <para>
  680. <emphasis>toArray()</emphasis>
  681. </para>
  682. <para>
  683. 選択した日付を、そのオブジェクトのロケールにもとづいて配列形式で返します。
  684. 返される配列は
  685. <acronym>PHP</acronym> の <ulink url="http://php.net/getdate">getdate()</ulink>
  686. 関数が返すものと同じ形式で、次のような要素を含みます。
  687. </para>
  688. <para>
  689. <itemizedlist>
  690. <listitem>
  691. <para>
  692. 日を表す '<emphasis>day</emphasis>' (<constant>Zend_Date::DAY_SHORT</constant>)
  693. </para>
  694. </listitem>
  695. <listitem>
  696. <para>
  697. 月を表す '<emphasis>month</emphasis>' (<constant>Zend_Date::MONTH_SHORT</constant>)
  698. </para>
  699. </listitem>
  700. <listitem>
  701. <para>
  702. 年を表す '<emphasis>year</emphasis>' (<constant>Zend_Date::YEAR</constant>)
  703. </para>
  704. </listitem>
  705. <listitem>
  706. <para>
  707. 時間を表す '<emphasis>hour</emphasis>' (<constant>Zend_Date::HOUR_SHORT</constant>)
  708. </para>
  709. </listitem>
  710. <listitem>
  711. <para>
  712. 分を表す '<emphasis>minute</emphasis>' (<constant>Zend_Date::MINUTE_SHORT</constant>)
  713. </para>
  714. </listitem>
  715. <listitem>
  716. <para>
  717. 秒を表す '<emphasis>second</emphasis>' (<constant>Zend_Date::SECOND_SHORT</constant>)
  718. </para>
  719. </listitem>
  720. <listitem>
  721. <para>
  722. タイムゾーンの略称を表す '<emphasis>timezone</emphasis>' (<constant>Zend_Date::TIMEZONE</constant>)
  723. </para>
  724. </listitem>
  725. <listitem>
  726. <para>
  727. Unix タイムスタンプを表す '<emphasis>timestamp</emphasis>' (<constant>Zend_Date::TIMESTAMP</constant>)
  728. </para>
  729. </listitem>
  730. <listitem>
  731. <para>
  732. 曜日番号を表す '<emphasis>weekday</emphasis>' (<constant>Zend_Date::WEEKDAY_DIGIT</constant>)
  733. </para>
  734. </listitem>
  735. <listitem>
  736. <para>
  737. 年初からの日数を表す '<emphasis>dayofyear</emphasis>' (<constant>Zend_Date::DAY_OF_YEAR</constant>)
  738. </para>
  739. </listitem>
  740. <listitem>
  741. <para>
  742. 週を表す '<emphasis>week</emphasis>' (<constant>Zend_Date::WEEK</constant>)
  743. </para>
  744. </listitem>
  745. <listitem>
  746. <para>
  747. <acronym>GMT</acronym> からの時差を表す '<emphasis>gmtsecs</emphasis>' (<constant>Zend_Date::GMT_SECS</constant>)
  748. </para>
  749. </listitem>
  750. </itemizedlist>
  751. </para>
  752. </entry>
  753. </row>
  754. <row>
  755. <entry><methodname>toValue()</methodname></entry>
  756. <entry>
  757. <para>
  758. <emphasis>toValue($part = null)</emphasis>
  759. </para>
  760. <para>
  761. 指定した日付要素 <varname>$part</varname> の、
  762. そのオブジェクトのロケールにもとづいた整数表現を返します。
  763. <varname>$part</varname> で <constant>Zend_Date::MONTH_NAME_SHORT</constant>
  764. のような非数値要素を選択した場合は、
  765. <constant>FALSE</constant> を返します。
  766. <emphasis>注意:</emphasis> このメソッドは
  767. <link linkend="id.date.basic.operations"><methodname>get()</methodname></link>
  768. をコールし、結果を <acronym>PHP</acronym> の integer 型にキャストします。つまり、
  769. <methodname>get()</methodname> の返す結果が非常に大きな数値を表す数値表現となり、
  770. それが <acronym>PHP</acronym> の integer 型の制限をこえた場合には予期せぬ結果となります。
  771. そのような場合は、かわりに <methodname>get()</methodname> を使用します。
  772. </para>
  773. </entry>
  774. </row>
  775. <row>
  776. <entry>
  777. <link linkend="id.date.basic.operations">get()</link>
  778. </entry>
  779. <entry>
  780. <para>
  781. <emphasis>get($part = null, $locale = null)</emphasis>
  782. </para>
  783. <para>
  784. このメソッドは、オブジェクトの日付要素 <varname>$part</varname>
  785. をロケール <varname>$locale</varname> に変換したものを、
  786. 文字列あるいは整数値で返します。
  787. 詳細な情報は <link linkend="id.date.basic.operations" />
  788. を参照ください。
  789. </para>
  790. </entry>
  791. </row>
  792. <row>
  793. <entry><methodname>now()</methodname></entry>
  794. <entry>
  795. <para>
  796. <emphasis>now($locale = null)</emphasis>
  797. </para>
  798. <para>
  799. この関数は、<command>new Zend_Date()</command> と同等です。
  800. これは、現在の日付を表す <classname>Zend_Date</classname>
  801. オブジェクトに、ロケール <varname>$locale</varname>
  802. を指定して返します。
  803. </para>
  804. </entry>
  805. </row>
  806. </tbody>
  807. </tgroup>
  808. </table>
  809. </sect2>
  810. <sect2 id="zend.date.others.fractions">
  811. <title>一秒未満の単位の扱い</title>
  812. <para>
  813. <classname>Zend_Date</classname> インスタンスに関する情報の取得をサポートするメソッド群について説明します。
  814. </para>
  815. <table id="zend.date.others.fractions.table">
  816. <title>日付の出力用メソッド</title>
  817. <tgroup cols="2">
  818. <thead>
  819. <row>
  820. <entry>メソッド</entry>
  821. <entry>説明</entry>
  822. </row>
  823. </thead>
  824. <tbody>
  825. <row>
  826. <entry>
  827. <para>
  828. <emphasis><methodname>getFractionalPrecision()</methodname></emphasis>
  829. </para>
  830. </entry>
  831. <entry>一秒未満の値の精度を返します。</entry>
  832. </row>
  833. <row>
  834. <entry>
  835. <para>
  836. <emphasis><methodname>setFractionalPrecision()</methodname></emphasis>
  837. </para>
  838. </entry>
  839. <entry>一秒未満の値の精度を設定します。</entry>
  840. </row>
  841. </tbody>
  842. </tgroup>
  843. </table>
  844. </sect2>
  845. <sect2 id="zend.date.other.sun">
  846. <title>日の出 / 日の入り</title>
  847. <para>
  848. これらの三つのメソッドにより、各地域に特化した太陽の情報を取得できます。
  849. たとえば日の出や日の入りの時刻などが得られます。
  850. </para>
  851. <table id="zend.date.other.sun.table">
  852. <title>雑多なメソッド</title>
  853. <tgroup cols="2">
  854. <thead>
  855. <row>
  856. <entry>メソッド</entry>
  857. <entry>説明</entry>
  858. </row>
  859. </thead>
  860. <tbody>
  861. <row>
  862. <entry>
  863. <para>
  864. <emphasis><methodname>getSunrise($location)</methodname></emphasis>
  865. </para>
  866. </entry>
  867. <entry>日の出時刻を返します。</entry>
  868. </row>
  869. <row>
  870. <entry>
  871. <para>
  872. <emphasis><methodname>getSunset($location)</methodname></emphasis>
  873. </para>
  874. </entry>
  875. <entry>日の入り時刻を返します。</entry>
  876. </row>
  877. <row>
  878. <entry>
  879. <para>
  880. <emphasis><methodname>getSunInfo($location)</methodname></emphasis>
  881. </para>
  882. </entry>
  883. <entry>日の出/日の入り情報を含む配列を返します。</entry>
  884. </row>
  885. </tbody>
  886. </tgroup>
  887. </table>
  888. </sect2>
  889. </sect1>
  890. <!--
  891. vim:se ts=4 sw=4 et:
  892. -->