Zend_Date-Introduction.xml 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.date.introduction">
  5. <title>導入</title>
  6. <para>
  7. <classname>Zend_Date</classname> コンポーネントは、
  8. 日付や時刻を操作するための、きめ細かくシンプルな <acronym>API</acronym> を提供します。
  9. このメソッドを使用すると、日付の各部分を含めた広範囲の情報を扱えます。
  10. さまざまな機能がもたらす可能性は、<acronym>PHP</acronym>
  11. の既存の日付関連の関数をはるかに上回っています。
  12. 最新のマニュアルは、
  13. <ulink url="http://framework.zend.com/wiki/display/ZFDOCDEV/Home">オンライン版
  14. (Subversion の更新と同期しています)</ulink>
  15. を参照ください。
  16. </para>
  17. <para>
  18. シンプルに扱えることを目標とはしていますが、
  19. 各地域の日付や時刻を操作 (変更や合成、比較など)
  20. する際にはある程度複雑になってしまうことは避けられません。
  21. 日付や時刻は、地域によって表記方法が異なることがよくあります。
  22. たとえば、カレンダーの日付を表す際にまず月が最初にくるところもあれば、
  23. 年が最初にくるところもあります。
  24. 地域の処理および正規化についての詳細は、
  25. <link linkend="zend.locale.date.datesandtimes"><classname>Zend_Locale</classname>
  26. </link>
  27. を参照ください。
  28. </para>
  29. <para>
  30. <classname>Zend_Date</classname> は、多くの言語における月名の短縮表記に対応しています。
  31. <classname>Zend_Locale</classname> は、タイムスタンプにおける各地域の月名や曜日名に対応しており、
  32. それを他の地域での表記に変換することもできます。
  33. </para>
  34. <sect2 id="zend.date.setdefaulttimezone">
  35. <title>デフォルトタイムゾーンの設定</title>
  36. <para>
  37. 日付関連の関数を <acronym>PHP</acronym> や Zend Framework で使う前には、
  38. まずアプリケーションにデフォルトタイムゾーンが設定されているかどうかを確認しましょう。
  39. これは、環境変数 TZ で指定するか、あるいは php.ini の設定
  40. <property>date.timezone</property> か
  41. <ulink url="http://php.net/date_default_timezone_set">date_default_timezone_set()</ulink>
  42. を使用して行います。
  43. <acronym>PHP</acronym> では、日付や時刻関連の関数が特定のユーザに対して動作するようにするには
  44. デフォルトのタイムゾーンを設定します。
  45. タイムゾーン設定の完全な一覧は、
  46. <ulink url="http://unicode.org/cldr/data/diff/supplemental/territory_containment_un_m_49.html">CLDR Timezone Identifier List</ulink>
  47. を参照ください。
  48. </para>
  49. <example id="zend.date.setdefaulttimezone.example-1">
  50. <title>デフォルトタイムゾーンの設定</title>
  51. <programlisting language="php"><![CDATA[
  52. // カリフォルニアのアメリカ人用のタイムゾーン
  53. date_default_timezone_set('America/Los_Angeles');
  54. // ドイツのドイツ人用のタイムゾーン
  55. date_default_timezone_set('Europe/Berlin');
  56. ]]></programlisting>
  57. </example>
  58. <para>
  59. <emphasis><classname>Zend_Date</classname> のインスタンスを作成すると、
  60. そのタイムゾーンは自動的に現在のデフォルトタイムゾーンになります!</emphasis>
  61. したがって、そのタイムゾーン設定は夏時間 (<acronym>DST</acronym>) も事実上考慮したものになるでしょう。
  62. 明示的に夏時間 (<acronym>DST</acronym>) を指定する必要はありません。
  63. </para>
  64. <para>
  65. タイムゾーン <emphasis><acronym>UTC</acronym></emphasis> および
  66. <emphasis><acronym>GMT</acronym></emphasis> には夏時間が存在しないことに注意しましょう。
  67. つまり、たとえ手動で夏時間を使うよう設定したとしても、
  68. <acronym>UTC</acronym> や <acronym>GMT</acronym> に設定された <classname>Zend_Date</classname>
  69. のインスタンスはその影響を受けないということです。
  70. </para>
  71. </sect2>
  72. <sect2 id="zend.date.why">
  73. <title>なぜ Zend_Date なのか?</title>
  74. <para>
  75. <classname>Zend_Date</classname> が提供する機能は次のとおりで、これは
  76. <acronym>PHP</acronym> の日付関数群を拡張したものです。
  77. </para>
  78. <itemizedlist mark='opencircle'>
  79. <listitem>
  80. <para>
  81. シンプルな <acronym>API</acronym>
  82. </para>
  83. <para>
  84. <classname>Zend_Date</classname> の提供する <acronym>API</acronym> は非常にシンプルです。
  85. これは、四つのプログラミング言語の日付および時刻に関連する機能から、
  86. いいところを抜き出してまとめたものです。
  87. たとえば、二つの時刻を加算したり比較したりすることは一行でできてしまいます。
  88. </para>
  89. </listitem>
  90. <listitem>
  91. <para>
  92. 完全な国際化
  93. </para>
  94. <para>
  95. 月名や曜日名とその短縮形について、130 以上の言語をサポートしています。
  96. メソッドの入力や出力で、これらの各地域の月名、曜日名を使用することができます。
  97. </para>
  98. </listitem>
  99. <listitem>
  100. <para>
  101. 制約のないタイムスタンプ
  102. </para>
  103. <para>
  104. <acronym>PHP</acronym> 5.2 のドキュメントでは "タイムスタンプの有効範囲は、通常は
  105. Fri, 13 Dec 1901 20:45:54 <acronym>GMT</acronym> から Tue, 19 Jan 2038 03:14:07 <acronym>GMT</acronym> までです"
  106. と書かれていますが、<classname>Zend_Date</classname> は
  107. ほぼ無制限に近い範囲をサポートしています。これは、BCMath
  108. 拡張モジュールのおかげです。
  109. BCMath が使用できない場合は、<classname>Zend_Date</classname> がサポートするタイムスタンプの範囲が制限され、
  110. 使用しているサーバのフロート型で対応できる範囲のみとなります。
  111. "float の大きさはプラットフォーム依存です。ただし、通常はおよそ 10
  112. 進数で 14 桁の精度があり、最大値は <command>~1.8e308</command> (これは 64ビット <acronym>IEEE</acronym>
  113. フォーマットです) となります。" [
  114. <ulink url="http://www.php.net/float">http://www.php.net/float</ulink>
  115. ]
  116. さらに、float 型そのものの特性により、計算結果に丸め誤差が生じる問題があります。
  117. これを避けるため、Zend Framework の I18n コンポーネントでは
  118. もし BCMath 拡張モジュールが使用可能ならそれを使用するようにしています。
  119. </para>
  120. </listitem>
  121. <listitem>
  122. <para>
  123. <acronym>ISO-8601</acronym> 日付仕様のサポート
  124. </para>
  125. <para>
  126. <acronym>ISO-8601</acronym> の日付仕様をサポートしています。
  127. <acronym>ISO-8601</acronym> の日付仕様の一部にのみ準拠しているものについても識別できます。
  128. これらの日付書式は、データベースを使用する際に特に有用です。
  129. たとえば、MsSQL と
  130. <ulink url="http://dev.mysql.com/doc/refman/5.0/en/date-and-time-functions.html">MySQL</ulink>
  131. の日付書式は微妙に異なりますが、
  132. <classname>Zend_Date</classname> は、書式指定定数
  133. <link linkend="zend.date.constants.list">Zend_Date::ISO_8601</link>
  134. によって両方ともサポートしています。
  135. 日付文字列が <acronym>PHP</acronym> の <methodname>date()</methodname> フォーマットトークンである
  136. "<command>Y/m/d</command>" や "<command>Y-m-d H:i:s</command>" といった形式になる場合は、
  137. <classname>Zend_Date</classname> が持つ <acronym>ISO-8601</acronym> 日付書式の組み込みサポートを使用します。
  138. </para>
  139. </listitem>
  140. <listitem>
  141. <para>
  142. 日の出、日の入り時刻の計算
  143. </para>
  144. <para>
  145. 任意の場所と日付に対する日の出、日の入り時刻を表示できます。
  146. これにより、一秒たりとも無駄にすることなく
  147. お好みの <acronym>PHP</acronym> プロジェクトで作業できることでしょう (^o^)
  148. </para>
  149. </listitem>
  150. </itemizedlist>
  151. </sect2>
  152. </sect1>
  153. <!--
  154. vim:se ts=4 sw=4 et:
  155. -->