Zend_Date-Overview.xml 56 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17986 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.date.overview">
  5. <title>Zend_Date API Übersicht</title>
  6. <para>
  7. Obwohl die <acronym>API</acronym> von <classname>Zend_Date</classname> simpel und eindeutig
  8. ist, ist dessen Design flexibel und mächtig durch die Vielzahl an Möglcihkeiten von
  9. Operationen und Operanden.
  10. </para>
  11. <sect2 id="zend.date.options">
  12. <title>Zend_Date Optionen</title>
  13. <sect3 id="zend.date.options.formattype">
  14. <title>Auswahl der Art des Datumsformats</title>
  15. <para>
  16. Viele Methoden benutzen Zeichenketten für Datumsformate so ähnlich wie
  17. <acronym>PHP</acronym>'s <methodname>date()</methodname>. Wenn man mit den Zeichen
  18. von <acronym>PHP</acronym>'s Datumsformaten mehr Erfahrung hat als mit den
  19. <acronym>ISO</acronym> Zeichen für Formate dann kann man
  20. <methodname>Zend_Date::setOptions(array('format_type' => 'php'))</methodname>
  21. benutzen. Danach können <acronym>PHP</acronym>'s Zeichen für Datumsformate für alle
  22. Funktionen verwendet werden die einen <varname>$format</varname> Parameter
  23. akzeptieren. Durch Benutzen von
  24. <methodname>Zend_Date::setOptions(array('format_type' => 'iso'))</methodname> kann
  25. man wieder auf den Standardmodus zurückwechseln der nur <acronym>ISO</acronym>
  26. Zeichen für Datumsformate unterstützt. Für eine Liste von unterstützten Zeichen
  27. Codes kann hier nachgelesen werden: <link
  28. linkend="zend.date.constants.phpformats" />
  29. </para>
  30. </sect3>
  31. <sect3 id="zend.date.options.fixdst">
  32. <title>Sommer-/Winterzeit und Datumsberechnungen</title>
  33. <para>
  34. Wenn Daten manipuliert werden überschreiten Sie manchmal die <acronym>DST</acronym>
  35. Grenze (Sommer-/Winterzeit) was normalerweise dazu führt das das Datum eine Stunde
  36. verliert oder hinzubekommt. Wenn zum Beispiel ein Monat zu einem Datum vor einer
  37. <acronym>DST</acronym> Änderung hinzugefügt wird und das Ergebnismonat nach dieser
  38. Änderung liegt, sieht es so aus als ob das Datum eine Stunde verliert oder
  39. hinzubekommt durch den Wert des geänderten Datums. Für Grenzstunden, wie Mitternacht
  40. für den ersten oder letzten Tag eines Monats, führt das Hinzufügen von genügend
  41. Monaten, wenn die <acronym>DST</acronym> Grenze überschritten wird, dazu dass das
  42. Datum eine Stunde verliert und damit zum letzten Tag des Vormonats wird durch das
  43. Erscheinungsbild des "eins fehlt" Fehlers. Um diese Situationen zu vermeiden, kann
  44. die <acronym>DST</acronym> Änderung durch Verwendung der <code>fix_dst</code> Option
  45. ignoriert werden. Wenn eine <acronym>DST</acronym> Grenze überschritten wird, wird
  46. ja normalerweise eine Stunde hinzugefügt oder entfernt abhändig vom Datum. Zum
  47. Beispiel führt eine Datumsberechnung mit <acronym>DST</acronym> im Frühling zu einem
  48. Datum welche einen Tag weniger hat als erwartet, wenn die Zeit des Originaldatums
  49. 00:00:00 war. Da <classname>Zend_Date</classname> auf Zeitpunkten basiert und nicht
  50. auf Kalenderdaten mit Zeitkomponenten, verliert der Zeitpunkt eine Stunde was zu
  51. einem Datum führt das einen Kalendertag weniger hat als erwartet. Um solche Problem
  52. zu verhindern kann die Option <code>fix_dst</code> verwendet werden, welche
  53. standardmäßig <constant>TRUE</constant> ist. Das führt dazu das die
  54. <acronym>DST</acronym> keinen Einfluß mehr bei Datumsberechnungen zeigt
  55. (<methodname>addMonth()</methodname>, <methodname>subMonth()</methodname>).
  56. <methodname>Zend_Date::setOptions(array('fix_dst' => false))</methodname> kann
  57. benutzt werden um Hinzufügen oder Entfernen der <acronym>DST</acronym> Anpassung zu
  58. gestatten wenn Datumsberechnungen durchgeführt werden.
  59. </para>
  60. <para>
  61. <emphasis>Wenn die aktuelle Zeitzone innerhalb der Instanz von
  62. <classname>Zend_Date</classname> auf <acronym>UTC</acronym> oder
  63. <acronym>GMT</acronym> gestellt wird, wird die Option <code>'fix_dst'</code> nicht
  64. verwendet</emphasis> weil diese zwei Zeitzonen nicht mit <acronym>DST</acronym>
  65. arbeiten. Wenn die Zeitzone für diese Instanz wieder auf eine Zeitzone gestellt wird
  66. die nicht <acronym>UTC</acronym> oder <acronym>GMT</acronym> ist, wird die vorher
  67. definierte 'fix_dst' Option wieder für die Datumsberechnungen verwendet.
  68. </para>
  69. </sect3>
  70. <sect3 id="zend.date.options.extendmonth">
  71. <title>Monatsberechnungen</title>
  72. <para>
  73. Wenn Monate von einem existierenden Datum hinzugefügt oder entfernt werden, kann der
  74. Ergebniswert des Monatstages unerwartet sein, wenn das Originaldatum auf einen Tag
  75. gefallen ist der Nahe am Ende des Monats ist. Wenn zum Beispiel ein Monat zum 31sten
  76. Jänner hinzugefügt wird, werden Personen welche mit <acronym>SQL</acronym> vertraut
  77. sind den 28sten Februar als Ergebnis erwarten. Auf der anderen Seite werden Personen
  78. welche mit Excel und OpenOffice vertraut sind werden den 3ten März als Ergebnis
  79. erwarten. Das Problem besteht nur wen das Ergebnismonat den Tag der im Originaldatum
  80. gesetzt war, nicht hat. Für Zend Framework Entwickler können das gewünschte
  81. Verhalten ausgewählen indem die Option <code>extend_month</code> genutzt wird um
  82. entweder das <acronym>SQL</acronym> Verhalten, wenn die Option
  83. <constant>FALSE</constant> ist, oder das Tabellenverhalten, wenn die Option
  84. <constant>TRUE</constant> ist, auszuwählen. Das Standardverhalten für
  85. <code>extend_month</code> ist <constant>FALSE</constant>, um <acronym>SQL</acronym>
  86. kompatibles Verhalten zu erlauben. <classname>Zend_Date</classname> führt
  87. Monatsberechnungen standardmäßig in der Art durch das Daten auf das Monatsende hin
  88. abgeschnitten werden (wenn notwendig), ohne das in den nächsten Monat umgebrochen
  89. wird wenn das Originaldatum einen Monatstag bestimmt der die Anzahl der Tag des
  90. Ergebnismonats überschreitet.
  91. <methodname>Zend_Date::setOptions(array('extend_month' => true))</methodname> kann
  92. benutzt werden um Monatsberechnungen wie in populären Tabellenkalkulationen
  93. durchzuführen.
  94. </para>
  95. </sect3>
  96. <sect3 id="zend.date.options.cache">
  97. <title>
  98. Lokalisierung und Normalisierung von Daten mit Zend_Cache schneller machen
  99. </title>
  100. <para>
  101. Man kann <classname>Zend_Date</classname> schneller machen indem ein
  102. <classname>Zend_Cache</classname> Adapter verwendet wird. Das verschnellert alle
  103. Methoden von <classname>Zend_Date</classname> wenn lokalisierte Daten verwendet
  104. werden. Zum Beispiel werden alle Methoden welche
  105. <constant>Zend_Date::DATE</constant> und <constant>Zend_Date::TIME</constant>
  106. Konstanten akzeptieren hiervon profitieren. Um einen
  107. <classname>Zend_Cache</classname> Adapter für <classname>Zend_Date</classname> zu
  108. setzen muß nur
  109. <methodname>Zend_Date::setOptions(array('cache' => $adapter))</methodname>
  110. aufgerufen werden.
  111. </para>
  112. </sect3>
  113. <sect3 id="zend.date.options.timesync">
  114. <title>Syncronisierte Zeiten mit Zend_TimeSync erhalten</title>
  115. <para>
  116. Normalerweise unterscheiden sich die Uhren von Servern und Computern voneinander.
  117. <classname>Zend_Date</classname> ist dazu fähig solche Probleme mit Hilfe von
  118. <classname>Zend_TimeSync</classname> zu handhaben. Mit
  119. <methodname>Zend_Date::setOptions(array('timesync' => $timeserver))</methodname>
  120. kann ein Zeitserver gesetzt werden welcher den Unterschied zwischen dem eigenen
  121. aktuellen Zeitpunkt und dem wirklichen aktuellen Zeitpunkt für alle Instanzen von
  122. <classname>Zend_Date</classname> setzt. Die Verwendung dieser Option ändern nicht
  123. den Zeitpunkt von bestehenden Instanzen. Am besten ist es also dies innerhalb der
  124. Bootstrap Datei zu setzen.
  125. </para>
  126. </sect3>
  127. </sect2>
  128. <sect2 id="zend.date.values">
  129. <title>Arbeiten mit Datumswerten</title>
  130. <para>
  131. Sobald die Eingabe durch die Erstellung eines <classname>Zend_Date</classname> Objektes
  132. normalisiert wurde, hat es eine zugeordnete Zeitzone aber eine Interne Darstellung durch
  133. Verwendung von <ulink
  134. url="http://en.wikipedia.org/wiki/Unix_Time">UNIX Zeitpunkten</ulink>. Damit ein
  135. Datum in einer lokalisierten Art und Weise durchsucht werden kann, muß zuerst eine
  136. Zeitzone bekannt sein. Die Standardzeitzone ist immer <acronym>GMT</acronym>/UTC. Um die
  137. Zeitzone des Objektes zu inspizieren kann <methodname>getTimeZone()</methodname>
  138. verwendet werden. Um die Zeitzone des Objektes zu wechseln kann
  139. <methodname>setTimeZone()</methodname> verwendet werden. Alle Änderungen des Objektes
  140. sind immer relativ zu seiner Zeitzone zu sehen.
  141. </para>
  142. <para>
  143. Aufpassen das nicht Teile von Datumsobjekten die unterschiedliche Zeitzonen haben,
  144. gemischt oder verglichen werden, da dies Grundsätzlich unerwartete Resultate zeigen kann
  145. da die Manipulationen nur dem Zeitpunkt zugeordnet werden. Das Arbeiten an
  146. <classname>Zend_Date</classname> Objekten die unterschiedliche Zeitzonen haben
  147. funktioniert grundsätzlich abgesehen davon wie vorher erwähnt, da Daten bei der
  148. Instantiierung von <classname>Zend_Date</classname> zu UNIX Zeitpunkten normalisiert
  149. werden.
  150. </para>
  151. <para>
  152. Die meisten Methoden erwarten eine Konstante für die Auswahl des gewünschten Teils
  153. <varname>$part</varname> des Datums, wie z.B. <constant>Zend_Date::HOUR</constant>.
  154. Diese Konstanten sind für alle unten angeführten Funktionen gültig. Eine Liste aller
  155. vorhandenen Konstanten wird hier beschrieben: <link
  156. linkend="zend.date.constants.list" />. Wenn <varname>$part</varname> nicht
  157. spezifiziert wird, wird <constant>Zend_Date::TIMESTAMP</constant> angenommen.
  158. Alternativ kann ein benutzerdefiniertes Format für <varname>$part</varname> verwendet
  159. werden, mit Hilfe der gleichen Mechanismen und Formatdefinitionen wie bei <link
  160. linkend="zend.locale.date.normalize"><methodname>Zend_Locale_Format::getDate()</methodname></link>.
  161. Wenn ein Datumsobjekt erstellt wird durch Verwendung eines offensichtlich falschen
  162. Datums (z.B. die Nummer des Monats größer als 12), wird <classname>Zend_Date</classname>
  163. eine Ausnahme werfen, solange kein spezielles Datumsformat ausgewählt wurde, und z.B.
  164. <varname>$part</varname> entweder <constant>NULL</constant> oder
  165. <constant>Zend_Date::DATES</constant> (ein "fehlertolerantes" Format).
  166. </para>
  167. <example id="zend.date.values.example-1">
  168. <title>Benutzerdefinierte Eingabeformate für Daten</title>
  169. <programlisting language="php"><![CDATA[
  170. $date1 = new Zend_Date('Feb 31, 2007', null, 'en_US');
  171. echo $date1, "\n"; // Ausgabe "Mar 3, 2007 12:00:00 AM"
  172. $date2 = new Zend_Date('Feb 31, 2007', Zend_Date::DATES, 'en_US');
  173. echo $date2, "\n"; // Ausgabe "Mar 3, 2007 12:00:00 AM"
  174. // Stikte Interpretation des angegebenen Formats
  175. $date3 = new Zend_Date('Feb 31, 2007', 'MM.dd.yyyy');
  176. echo $date3, "\n"; // Ausgabe "Mar 3, 2007 12:00:00 AM"
  177. ]]></programlisting>
  178. </example>
  179. <para>
  180. Wenn der optionale <varname>$locale</varname> Parameter angegeben wurde, dann
  181. verdeutlicht <varname>$locale</varname> den <varname>$date</varname> Operand durch
  182. Ersetzen der Monatsnamen und Wochentagsnamen für die <varname>$date</varname>
  183. Zeichenkette, und auch Datumszeichenketten können analysiert werden durch die
  184. Vorschriften dieses Gebietsschemas (siehe <code><link
  185. linkend="zend.locale.date.normalize">Zend_Locale_Format::getDate()</link></code>).
  186. Die automatische Normalisierung von lokalisierten <varname>$date</varname> Angaben einer
  187. Zeichenkette werden nur dann durchgeführt wenn für <varname>$part</varname> eine der
  188. <constant>Zend_Date::DATE</constant>* oder <constant>Zend_Date::TIME</constant>*
  189. Konstanten verwendet wird. Das Gebietsschema identifiziert die Sprache welche verwendet
  190. werden soll um Monatsnamen und Wochentagsnamen zu analysieren wenn
  191. <varname>$date</varname> eine Zeichenkette ist die ein Datum enthält. Wenn der
  192. Eingabeparameter <varname>$date</varname> nicht angegeben wurde, dann definiert der
  193. <varname>$locale</varname> Parameter das Gebietsschema für lokalisierte Ausgaben (z.B.
  194. das Datumsformat für eine Ausgabe als Zeichenkette). Anzumerken ist auch das der
  195. <varname>$date</varname> Parameter stattdessen ein Typname sein kann (z.B.
  196. <varname>$hour</varname> für <methodname>addHour()</methodname>), und das verhindert
  197. auch nicht das ein <classname>Zend_Date</classname> Objekt als Argument für diesen
  198. Parameter angegeben werden kann. Wenn keine <varname>$locale</varname> angegeben wurde,
  199. wird das Gebietsschema des aktuellen Objektes genommen um <varname>$date</varname> zu
  200. interpretieren oder das lokalisierte Format für die Ausgabe auszuwählen.
  201. </para>
  202. <para>
  203. Seit Zend Framework 1.7.0 unterstützt <classname>Zend_Date</classname> auch die
  204. Verwendung eines Anwendungsweiten Gebietsschemas. Man kann ganz einfach eine
  205. <classname>Zend_Locale</classname> Instanz in der Registry setzen wie anbei gezeigt. Mit
  206. dieser Schreibweise kann man das manuelle Setzen eines Gebietsschemas für jede Instanz
  207. vergessen wenn man das selbe Gebietsschema mehrere Male verwenden will.
  208. </para>
  209. <programlisting language="php"><![CDATA[
  210. // In der Bootstrap Datei
  211. $locale = new Zend_Locale('de_AT');
  212. Zend_Registry::set('Zend_Locale', $locale);
  213. // Irgendwo in der eigenen Anwendung
  214. $date = new Zend_Date('31.Feb.2007');
  215. ]]></programlisting>
  216. </sect2>
  217. <sect2 id="id.date.basic">
  218. <title>Grundsätzliche Zend_Date Operationen für die meisten Teile von Daten</title>
  219. <para>
  220. Die Methoden <methodname>add()</methodname>, <methodname>sub()</methodname>,
  221. <methodname>compare()</methodname>, <methodname>get()</methodname>, und
  222. <methodname>set()</methodname> arbeiten generell mit Daten. In Jedem Fall wird die
  223. Operation auf dem Datum durchgeführt das in den Objektinstanz vorhanden ist. Der
  224. <varname>$date</varname> Operand wird für alle dieser Methoden benötigt, ausser für
  225. <methodname>get()</methodname> und kann eine <classname>Zend_Date</classname>
  226. Objektinstanz, eine nummerische Zeichenkette oder ein Integer sein. Diese Methoden
  227. nehmen an das <varname>$date</varname> ein Zeitpunkt ist, wenn es kein Objekt ist.
  228. Trotzdem kontrolliert der <varname>$part</varname> Operand an welchem logischen Teil
  229. der zwei Daten gearbeitet werden soll, was Arbeiten an Teilen von Daten des Objekts
  230. erlaubt, wie Jahr oder Minute selbst wenn <varname>$date</varname> eine lange Form
  231. einer Datumszeichenkette enthält wie "Dezember 31, 2007 23:59:59". Das Ergebnis der
  232. Operation ändert das Datum im Objekt ausser bei <methodname>compare()</methodname> und
  233. <methodname>get()</methodname>.
  234. </para>
  235. <example id="zend.date.basic.example-1">
  236. <title>Arbeiten an Teilen von Daten</title>
  237. <programlisting language="php"><![CDATA[
  238. $date = new Zend_Date(); // $date's Zeitpunkt === time()
  239. // Ändert $date durch addieren von 12 Stunden
  240. $date->add('12', Zend_Date::HOUR);
  241. print $date;
  242. ]]></programlisting>
  243. </example>
  244. <para>
  245. Übliche Methoden existieren für jede Kombination von Basisarbeiten und viele normale
  246. Datumsabschnitte wie in der Tabelle anbei gezeigt. Diese üblichen Methoden erlauben uns
  247. faulen Programmierern zu vermeiden das die <link
  248. linkend="zend.date.constants.list">Konstanten für Datumsabschnitte</link>
  249. ausgeschrieben werden müssen. Normalerweise sind wir benannt durch Kombination eines
  250. Prefixes (Name der Basisoperation) und einem Suffix (Art des Datumsabschnittes), wie
  251. <methodname>addYear()</methodname>. In der Liste die anbei steht, existieren alle
  252. Kombinationen von "Datumsabschnitten" und "Basisoperationen". Zum Beispiel die
  253. Operation "add" existiert für jeden dieser Datumsabschnitte wie
  254. <methodname>addDay()</methodname>, <methodname>addYear()</methodname> und viele mehr.
  255. </para>
  256. <para>
  257. Diese üblichen Methoden haben die selbe gleichartige Funktionalität wie die Methoden für
  258. die Basisoperationen, aber Sie erwarten Zeichenkette und Integer
  259. <varname>$date</varname> Operanden welche nur die Werte enthalten welche durch den Typ
  260. definiert sind der durch den Suffix der Methode definiert wurde. Deshalb identifizieren
  261. diese Methoden (z.B. "Year" oder "Minute") die Einheit des <varname>$date</varname>
  262. Operanden wenn <varname>$date</varname> eine Zeichenkette oder ein Integer ist
  263. </para>
  264. <sect3 id="id.date.basic.parts">
  265. <title>Liste der Datumsabschnitte</title>
  266. <table id="id.date.basic.parts.table">
  267. <title>Datumsabschnitte</title>
  268. <tgroup cols="2">
  269. <thead>
  270. <row>
  271. <entry>Datumsabschnitt</entry>
  272. <entry>Erklärung</entry>
  273. </row>
  274. </thead>
  275. <tbody>
  276. <row>
  277. <entry>
  278. <ulink url="http://en.wikipedia.org/wiki/Unix_Time">Zeitpunkt</ulink>
  279. </entry>
  280. <entry>
  281. UNIX Zeitpunkt, ausgedrückt in Sekunden die vergangen sind seit dem
  282. 1. Jänner, 1970 00:00:00 <acronym>GMT</acronym>/UTC.
  283. </entry>
  284. </row>
  285. <row>
  286. <entry>
  287. <ulink url="http://en.wikipedia.org/wiki/Gregorian_calendar">Jahr</ulink>
  288. </entry>
  289. <entry>Gregorianisches Kalenderjahr (z.B. 2006)</entry>
  290. </row>
  291. <row>
  292. <entry>
  293. <ulink url="http://en.wikipedia.org/wiki/Month#Julian_and_Gregorian_calendars">Monat</ulink>
  294. </entry>
  295. <entry>
  296. Gregorianisches Kalendermonat (1-12, Lokalisierte Namen werden
  297. unterstützt)
  298. </entry>
  299. </row>
  300. <row>
  301. <entry>
  302. <ulink url="http://en.wikipedia.org/wiki/24-hour_clock">24 Stunden
  303. Uhr</ulink>
  304. </entry>
  305. <entry>
  306. Stunde des Tages (0-23) bezeichnet die vergangenen Stunden seit dem
  307. Beginn des Tages
  308. </entry>
  309. </row>
  310. <row>
  311. <entry>
  312. <ulink url="http://en.wikipedia.org/wiki/Minute">Minute</ulink>
  313. </entry>
  314. <entry>
  315. Minuten der Stunde (0-59) bezeichnet die vergangenen Minuten seit
  316. dem Beginn der Stunde
  317. </entry>
  318. </row>
  319. <row>
  320. <entry>
  321. <ulink url="http://en.wikipedia.org/wiki/Second">Sekunde</ulink>
  322. </entry>
  323. <entry>
  324. Sekunde der Minute (0-59) bezeichnet die vergangenen Sekunden seit
  325. dem Beginn der Minute
  326. </entry>
  327. </row>
  328. <row>
  329. <entry>
  330. <ulink url="http://en.wikipedia.org/wiki/Millisecond">Millisekunde</ulink>
  331. </entry>
  332. <entry>
  333. Millisekunden bezeichnen Tausendstel einer Sekunde (0-999).
  334. <classname>Zend_Date</classname> unterstützt zwei zusätzliche
  335. Methoden für das Arbeiten mit Zeiteinheiten die kleiner als Sekunden
  336. sind. Normalerweise verwenden <classname>Zend_Date</classname>
  337. Instanzen eine Genauigkeit welche der von Millisekunden entspricht
  338. wie man durch <methodname>getFractionalPrecision()</methodname> sehen
  339. kann. Um die Genauigkeit zu Ändern kann
  340. <methodname>setFractionalPrecision($precision)</methodname> verwendet
  341. werden. Trotzdem ist die Genauigkeit praktisch auf Millisekunden
  342. begrezt da <classname>Zend_Date</classname> <code><ulink
  343. url="http://php.net/microtime">microtime()</ulink></code> dafür
  344. benutzt.
  345. </entry>
  346. </row>
  347. <row>
  348. <entry>
  349. <ulink url="http://en.wikipedia.org/wiki/Day">Tag</ulink>
  350. </entry>
  351. <entry>
  352. <constant>Zend_Date::DAY_SHORT</constant> wird von
  353. <varname>$date</varname> extrahiert wenn der
  354. <varname>$date</varname> Operand eine
  355. <classname>Zend_Date</classname> Instanz oder eine nummerische
  356. Zeichenkette ist. Sonst wird versucht den Tag laut den
  357. dokumentierten Konventionen für diese Konstanten zu extrahieren:
  358. <constant>Zend_Date::WEEKDAY_NARROW</constant>,
  359. <constant>Zend_Date::WEEKDAY_NAME</constant>,
  360. <constant>Zend_Date::WEEKDAY_SHORT</constant>,
  361. <constant>Zend_Date::WEEKDAY</constant> (Gregorianischer Kalender
  362. angenommen)
  363. </entry>
  364. </row>
  365. <row>
  366. <entry>
  367. <ulink url="http://en.wikipedia.org/wiki/Week">Woche</ulink>
  368. </entry>
  369. <entry>
  370. <constant>Zend_Date::WEEK</constant> wird von
  371. <varname>$date</varname> extrahiert wenn der
  372. <varname>$date</varname> Operand eine Instanz von
  373. <classname>Zend_Date</classname> oder eine nummerische Zeichenkette
  374. ist. Sonst wird eine Ausnahme geworfen. (Gregorianischer Kalender
  375. angenommen)
  376. </entry>
  377. </row>
  378. <row>
  379. <entry>Datum</entry>
  380. <entry>
  381. <constant>Zend_Date::DAY_MEDIUM</constant> wird aus
  382. <varname>$date</varname> extrahiert wenn der
  383. <varname>$date</varname> Operand eine Instanz von
  384. <classname>Zend_Date</classname> ist. Sonst wird versucht den
  385. <varname>$date</varname> String des Datums
  386. in ein Zend_Date::DATE_MEDIUM formatiertes Datum zu normalisieren.
  387. Das Format von <constant>Zend_Date::DATE_MEDIUM</constant> hängt
  388. vom Gebietsschema des Objektes ab.
  389. </entry>
  390. </row>
  391. <row>
  392. <entry>Wochentage</entry>
  393. <entry>
  394. Wochentage werden nummerisch dargestellt von 0 (für Sonntag) bis 6
  395. (für Samstag). <constant>Zend_Date::WEEKDAY_DIGIT</constant> wird
  396. aus <varname>$date</varname> extrahiert wenn der
  397. <varname>$date</varname> Operand eine Instanz von
  398. <classname>Zend_Date</classname> oder eine numerische Zeichenkette
  399. ist. Sonst wird versucht den Tag laut den dokumentierten
  400. Konventionen für diese Konstanten zu extrahieren:
  401. <constant>Zend_Date::WEEKDAY_NARROW</constant>,
  402. <constant>Zend_Date::WEEKDAY_NAME</constant>,
  403. <constant>Zend_Date::WEEKDAY_SHORT</constant>,
  404. <constant>Zend_Date::WEEKDAY</constant> (Gregorianischer Kalender
  405. angenommen)
  406. </entry>
  407. </row>
  408. <row>
  409. <entry>Tag des Jahres</entry>
  410. <entry>
  411. In <classname>Zend_Date</classname> wird der Tag des Jahres als
  412. Anzahl der Kalendertage dargestellt die seit dem Start des Jahres
  413. vergangen sind (0-365). Wie bei den anderen oben dargestellten
  414. Einheiten werden Bruchteile auf die nächste ganze Nummer abgerundet.
  415. (Gregorianischer Kalender angenommen)
  416. </entry>
  417. </row>
  418. <row>
  419. <entry>
  420. <ulink url="http://www.faqs.org/rfcs/rfc822.html">Arpa</ulink>
  421. </entry>
  422. <entry>
  423. Arpa Daten (bzw <acronym>RFC</acronym> 822 formatierte Daten) werden
  424. unterstützt. Die Ausgabe verwendet entweder "GMT" oder "Laut
  425. Gebietsschema unterschiedliche Stunden + Minuten" Format (siehe
  426. Sektion 5 von <acronym>RFC</acronym> 822). Vor
  427. <acronym>PHP</acronym> 5.2.2, zeigte die Verwendung der DATE_RFC822
  428. Konstante mit <acronym>PHP</acronym> date Funktionen hier und da
  429. <ulink url="http://bugs.php.net/bug.php?id=40308">fehlerhafte
  430. Ergebnisse</ulink>. Die Ergebnisse von
  431. <classname>Zend_Date</classname> sind korrekt. Beispiel:
  432. <code>Mon, 31 Dec 06 23:59:59 GMT</code>
  433. </entry>
  434. </row>
  435. <row>
  436. <entry>
  437. <ulink url="http://en.wikipedia.org/wiki/ISO_8601">Iso</ulink>
  438. </entry>
  439. <entry>
  440. Für die Ausgabe werden nur vollständige <acronym>ISO</acronym> 8601
  441. Daten unterstützt. Beispiel: <code>2009-02-14T00:31:30+01:00</code>
  442. </entry>
  443. </row>
  444. </tbody>
  445. </tgroup>
  446. </table>
  447. </sect3>
  448. <sect3 id="id.date.basic.operations">
  449. <title>Liste der Datums-Operationen</title>
  450. <para>
  451. Die unten angeführten Basisoperationen können statt den bequemlichen Operationen für
  452. spezielle Datumsabschnitte verwendet werden. Die <link
  453. linkend="zend.date.constants.list">entsprechenden Konstanten</link> werden für
  454. den <varname>$part</varname> Parameter verwendet.
  455. </para>
  456. <table id="id.date.basic.operations.table">
  457. <title>Basis Operationen</title>
  458. <tgroup cols="2">
  459. <thead>
  460. <row>
  461. <entry>Basis Operationen</entry>
  462. <entry>Erklärung</entry>
  463. </row>
  464. </thead>
  465. <tbody>
  466. <row>
  467. <entry><methodname>get()</methodname></entry>
  468. <entry>
  469. <para>
  470. <emphasis>get($part = null, $locale = null)</emphasis>
  471. </para>
  472. <para>
  473. <methodname>get($part)</methodname> kann benutzt werden um einen
  474. Datumsabschnitt <varname>$part</varname> dieses Datumsobjektes
  475. welcher in ein Gebietsschema von <varname>$locale</varname>
  476. lokalisiert oder als formatierte Zeichenkette oder Integer
  477. gewünscht ist zurück zu bekommen. Durch Verwendung der BCMath
  478. Erweiterung können nummerische Zeichenkettten statt Integer für
  479. große Werte zurückgegeben werden. <emphasis>NOTE:</emphasis>
  480. Anders als <methodname>get()</methodname> geben die anderen
  481. get*() bequemlichen Methoden nur Instanzen von
  482. <classname>Zend_Date</classname> zurück welche nur das Datum
  483. oder die Zeit repräsentieren das ausgewählt oder berechnet
  484. wurde.
  485. </para>
  486. </entry>
  487. </row>
  488. <row>
  489. <entry><methodname>set()</methodname></entry>
  490. <entry>
  491. <para>
  492. <emphasis>set($date, $part = null, $locale = null)</emphasis>
  493. </para>
  494. <para>
  495. Setzt den Abschnitt <varname>$part</varname> des aktuellen
  496. Objektes übereinstimmend mit dem Wert der für diesen Abschnitt
  497. in der Eingabe <varname>$date</varname> und im Gebietsschema
  498. <varname>$locale</varname> gefunden wurde.
  499. </para>
  500. </entry>
  501. </row>
  502. <row>
  503. <entry><methodname>add()</methodname></entry>
  504. <entry>
  505. <para>
  506. <emphasis>add($date, $part = null, $locale = null)</emphasis>
  507. </para>
  508. <para>
  509. Addiert den Abschnitt <varname>$part</varname> von
  510. <varname>$date</varname> welcher im Gebietsschema
  511. <varname>$locale</varname> geschrieben ist zum Datum des
  512. aktuellen Objektes.
  513. </para>
  514. </entry>
  515. </row>
  516. <row>
  517. <entry><methodname>sub()</methodname></entry>
  518. <entry>
  519. <para>
  520. <emphasis>sub($date, $part = null, $locale = null)</emphasis>
  521. </para>
  522. <para>
  523. Subtrahiert den Abschnitt <varname>$part</varname> von
  524. <varname>$date</varname> welcher im Gebietsschema
  525. <varname>$locale</varname> geschrieben ist vom Datum des
  526. aktuellen Objektes.
  527. </para>
  528. </entry>
  529. </row>
  530. <row>
  531. <entry><methodname>copyPart()</methodname></entry>
  532. <entry>
  533. <para>
  534. <emphasis>copyPart($part, $locale = null)</emphasis>
  535. </para>
  536. <para>
  537. Gibt ein geklontes Objekt zurück, wobei nur der gewünschte
  538. Abschnitt <varname>$part</varname> des Datumsobjektes kopiert
  539. wird, wobei im Klon das Gebietsschema von
  540. <varname>$locale</varname> gesetzt wird (wenn angegeben).
  541. </para>
  542. </entry>
  543. </row>
  544. <row>
  545. <entry><methodname>compare()</methodname></entry>
  546. <entry>
  547. <para>
  548. <emphasis>compare($date, $part = null, $locale =
  549. null)</emphasis>
  550. </para>
  551. <para>
  552. Vergleicht den Abschnitt <varname>$part</varname> des Datums
  553. <varname>$date</varname> mit dem Zeitpunkt des Objektes. Gibt 0
  554. zurück wenn sie gleich sind, 1 wenn wenn der Abschnitt dieses
  555. Objektes früher war als der Abschnitt von $date und andernfalls
  556. -1.
  557. </para>
  558. </entry>
  559. </row>
  560. </tbody>
  561. </tgroup>
  562. </table>
  563. </sect3>
  564. </sect2>
  565. <sect2 id="zend.date.others.comparison">
  566. <title>Vergleichen von Daten</title>
  567. <para>
  568. Die folgenden Basisoperationen haben keine vergleichbaren vereinfachten Methoden für
  569. Datumsabschnitt wie beschrieben unter <link linkend="zend.date.overview" />.
  570. </para>
  571. <table id="zend.date.others.comparison.table">
  572. <title>Methoden zum Vergleichen von Daten</title>
  573. <tgroup cols="2">
  574. <thead>
  575. <row>
  576. <entry>Methoden</entry>
  577. <entry>Beschreibung</entry>
  578. </row>
  579. </thead>
  580. <tbody>
  581. <row>
  582. <entry><methodname>equals()</methodname></entry>
  583. <entry>
  584. <para>
  585. <emphasis>equals($date, $part = null, $locale = null)</emphasis>
  586. </para>
  587. <para>
  588. Gibt <constant>TRUE</constant> zurück wenn der Abschnitt
  589. <varname>$part</varname> von <varname>$date</varname> der das
  590. Gebietsschema <varname>$locale</varname> hat, der gleiche ist wie
  591. der Abschnitt <varname>$part</varname> vom Datum des Objektes,
  592. andernfalls <constant>FALSE</constant>
  593. </para>
  594. </entry>
  595. </row>
  596. <row>
  597. <entry><methodname>isEarlier()</methodname></entry>
  598. <entry>
  599. <para>
  600. <emphasis>isEarlier($date, $part = null, $locale = null)</emphasis>
  601. </para>
  602. <para>
  603. Gibt <constant>TRUE</constant> zurück wenn der Abschnitt
  604. <varname>$part</varname> vom Datum des Objektes früher ist als der
  605. Abschnitt <varname>$part</varname> von <varname>$date</varname> der
  606. das Gebietsschema <varname>$locale</varname> hat
  607. </para>
  608. </entry>
  609. </row>
  610. <row>
  611. <entry><methodname>isLater()</methodname></entry>
  612. <entry>
  613. <para>
  614. <emphasis>isLater($date, $part = null, $locale = null)</emphasis>
  615. </para>
  616. <para>
  617. Gibt <constant>TRUE</constant> zurück wenn der Abschnitt
  618. <varname>$part</varname> vom Datum des Objektes später ist als der
  619. Abschnitt <varname>$part</varname> von <varname>$date</varname> der
  620. das Gebietsschema <varname>$locale</varname> hat
  621. </para>
  622. </entry>
  623. </row>
  624. <row>
  625. <entry><methodname>isToday()</methodname></entry>
  626. <entry>
  627. <para>
  628. <emphasis>isToday()</emphasis>
  629. </para>
  630. <para>
  631. Testet ob Jahr, Monat und Tag des heutigen Datums mit dem Datumswert
  632. des Objektes übereinstimmen, wenn die Zeitzone des Objektes
  633. verwendet wird.
  634. </para>
  635. </entry>
  636. </row>
  637. <row>
  638. <entry><methodname>isTomorrow()</methodname></entry>
  639. <entry>
  640. <para>
  641. <emphasis>isTomorrow()</emphasis>
  642. </para>
  643. <para>
  644. Testet ob Jahr, Monat und Tag des morgigen Datums mit dem Datumswert
  645. des Objektes übereinstimmen, wenn die Zeitzone des Objektes
  646. verwendet wird.
  647. </para>
  648. </entry>
  649. </row>
  650. <row>
  651. <entry><methodname>isYesterday()</methodname></entry>
  652. <entry>
  653. <para>
  654. <emphasis>isYesterday()</emphasis>
  655. </para>
  656. <para>
  657. Testet ob Jahr, Monat und Tag des gestrigen Datums mit dem
  658. Datumswert des Objektes übereinstimmen, wenn die Zeitzone des
  659. Objektes verwendet wird.
  660. </para>
  661. </entry>
  662. </row>
  663. <row>
  664. <entry><methodname>isLeapYear()</methodname></entry>
  665. <entry>
  666. <para>
  667. <emphasis>isLeapYear()</emphasis>
  668. </para>
  669. <para>
  670. <methodname>isLeapYear()</methodname> kann benutzt werden ob zu
  671. prüfen ob das aktuelle Objekt ein Schaltjahr ist. Sonst kann
  672. <methodname>Zend_Date::checkLeapYear($year)</methodname> benutzt
  673. werden um das Jahr <varname>$year</varname> zu prüfen, welches eine
  674. Zeichenkette, ein Integer oder eine Instanz von
  675. <classname>Zend_Date</classname> sein kann. Ist das Jahr ein
  676. Schaltjahr ?
  677. </para>
  678. </entry>
  679. </row>
  680. <row>
  681. <entry><methodname>isDate()</methodname></entry>
  682. <entry>
  683. <para>
  684. <emphasis>isDate($date, $format = null, $locale = null)</emphasis>
  685. </para>
  686. <para>
  687. Diese Methode prüft ob ein angegebenes Datum ein echtes Datum ist,
  688. und gibt <constant>TRUE</constant> zurück wenn alle Prüfungen in
  689. Ordnung waren. Sie arbeitet wie <acronym>PHP</acronym>'s checkdate()
  690. Funktion, kann aber auch lokalisierte Monatsnamen prüfen sowie Daten
  691. die den Bereich von checkdate() übersteigen
  692. </para>
  693. </entry>
  694. </row>
  695. </tbody>
  696. </tgroup>
  697. </table>
  698. </sect2>
  699. <sect2 id="zend.date.others.gettingparts">
  700. <title>Daten und Teile von Daten erhalten</title>
  701. <para>
  702. Verschiedene Methoden unterstützen das erhalten von Werten die auf eine
  703. <classname>Zend_Date</classname> Instanz bezug nehmen.
  704. </para>
  705. <table id="zend.date.others.gettingparts.table">
  706. <title>Ausgabemethoden von Daten</title>
  707. <tgroup cols="2">
  708. <thead>
  709. <row>
  710. <entry>Methode</entry>
  711. <entry>Erklärung</entry>
  712. </row>
  713. </thead>
  714. <tbody>
  715. <row>
  716. <entry><methodname>toString()</methodname></entry>
  717. <entry>
  718. <para>
  719. <emphasis>toString($format = null, $locale = null)</emphasis>
  720. </para>
  721. <para>
  722. Direkt aufzurufen oder über die magische Methode
  723. <methodname>__toString()</methodname>. Die
  724. <methodname>toString()</methodname> Methode formatiert automatisch
  725. den Wert des Datumsobjektes anhand der Konventionen des
  726. Gebietsschemas des Objektes, oder einem optional definierten
  727. Gebietsschema <varname>$locale</varname>. Für eine Liste von
  728. unterstützten Formatcodes kann hier nachgeschaut werden:
  729. <link linkend="zend.date.constants.selfdefinedformats" />.
  730. </para>
  731. </entry>
  732. </row>
  733. <row>
  734. <entry><methodname>toArray()</methodname></entry>
  735. <entry>
  736. <para>
  737. <emphasis>toArray()</emphasis>
  738. </para>
  739. <para>
  740. Gibt eine Array Representation des ausgewählten Datums anhand der
  741. Konventionen des Gebietsschemas zurück. Das zurückgegebene Array ist
  742. identisch zu <acronym>PHP</acronym>'s <ulink
  743. url="http://php.net/getdate">getdate()</ulink> Funktion und
  744. beinhaltet:
  745. </para>
  746. <para>
  747. <itemizedlist>
  748. <listitem>
  749. <para>
  750. Tag als Zahl mit '<emphasis>day</emphasis>'
  751. (<constant>Zend_Date::DAY_SHORT</constant>)
  752. </para>
  753. </listitem>
  754. <listitem>
  755. <para>
  756. Monat als Zahl mit '<emphasis>month</emphasis>'
  757. (<constant>Zend_Date::MONTH_SHORT</constant>)
  758. </para>
  759. </listitem>
  760. <listitem>
  761. <para>
  762. Jahr als '<emphasis>year</emphasis>'
  763. (<constant>Zend_Date::YEAR</constant>)
  764. </para>
  765. </listitem>
  766. <listitem>
  767. <para>
  768. Stunde als '<emphasis>hour</emphasis>'
  769. (<constant>Zend_Date::HOUR_SHORT</constant>)
  770. </para>
  771. </listitem>
  772. <listitem>
  773. <para>
  774. Minute als '<emphasis>minute</emphasis>'
  775. (<constant>Zend_Date::MINUTE_SHORT</constant>)
  776. </para>
  777. </listitem>
  778. <listitem>
  779. <para>
  780. Sekunde als '<emphasis>second</emphasis>'
  781. (<constant>Zend_Date::SECOND_SHORT</constant>)
  782. </para>
  783. </listitem>
  784. <listitem>
  785. <para>
  786. Abgekürzte Zeitzone als '<emphasis>timezone</emphasis>'
  787. (<constant>Zend_Date::TIMEZONE</constant>)
  788. </para>
  789. </listitem>
  790. <listitem>
  791. <para>
  792. Unix Zeitpunkt als '<emphasis>timestamp</emphasis>'
  793. (<constant>Zend_Date::TIMESTAMP</constant>)
  794. </para>
  795. </listitem>
  796. <listitem>
  797. <para>
  798. Wochentag als Zahl mit '<emphasis>weekday</emphasis>'
  799. (<constant>Zend_Date::WEEKDAY_DIGIT</constant>)
  800. </para>
  801. </listitem>
  802. <listitem>
  803. <para>
  804. Tag des Jahres als '<emphasis>dayofyear</emphasis>'
  805. (<constant>Zend_Date::DAY_OF_YEAR</constant>)
  806. </para>
  807. </listitem>
  808. <listitem>
  809. <para>
  810. Woche als '<emphasis>week</emphasis>'
  811. (<constant>Zend_Date::WEEK</constant>)
  812. </para>
  813. </listitem>
  814. <listitem>
  815. <para>
  816. Abstand der Zeitzone zu <acronym>GMT</acronym> als
  817. '<emphasis>gmtsecs</emphasis>'
  818. (<constant>Zend_Date::GMT_SECS</constant>)
  819. </para>
  820. </listitem>
  821. </itemizedlist>
  822. </para>
  823. </entry>
  824. </row>
  825. <row>
  826. <entry><methodname>toValue()</methodname></entry>
  827. <entry>
  828. <para>
  829. <emphasis>toValue($part = null)</emphasis>
  830. </para>
  831. <para>
  832. Gibt eine Integer Repräsentation des ausgewählten Datumsabschnittes
  833. <varname>$part</varname> zurück anhand der Konventionen des
  834. Gebietsschemas des Objektes. Gibt <constant>FALSE</constant> zurück
  835. wenn der Abschnitt <varname>$part</varname> ein nicht numerischer
  836. Wert ist, wie <constant>Zend_Date::MONTH_NAME_SHORT</constant>.
  837. <emphasis>NOTIZ:</emphasis> Diese Methode ruft <link
  838. linkend="id.date.basic.operations"><methodname>get()</methodname></link>
  839. auf und castet das Ergebnis einen <acronym>PHP</acronym> Integer
  840. Wert, welcher unerwartete Ergebnisse liefern wird, wenn
  841. <methodname>get()</methodname> eine numerische Zeichenkette
  842. zurückgibt die eine Zahl enthält welche zu groß für einen
  843. <acronym>PHP</acronym> Integer Wert auf Ihrem System ist.
  844. Stattdessen sollte <methodname>get()</methodname> benutzt werden.
  845. </para>
  846. </entry>
  847. </row>
  848. <row>
  849. <entry>
  850. <link linkend="id.date.basic.operations">get()</link>
  851. </entry>
  852. <entry>
  853. <para>
  854. <emphasis>get($part = null, $locale = null)</emphasis>
  855. </para>
  856. <para>
  857. Diese Methode gibt den Abschnitt <varname>$part</varname> vom Datum des
  858. Objektes, welches mit dem Gebietsschema <varname>$locale</varname>
  859. lokalisiert wurde, als formatierten String oder Integer zurück. Für
  860. weitere Informationen hier weiterlesen:
  861. <link linkend="id.date.basic.operations" />.
  862. </para>
  863. </entry>
  864. </row>
  865. <row>
  866. <entry><methodname>now()</methodname></entry>
  867. <entry>
  868. <para>
  869. <emphasis>now($locale = null)</emphasis>
  870. </para>
  871. <para>
  872. Diese bequemliche Funktion ist identisch mit
  873. <command>new Zend_Date()</command>. Sie gibt das aktuelle Datum als
  874. <classname>Zend_Date</classname> Objekt zurück, welches das
  875. Gebietsschema <varname>$locale</varname> hat.
  876. </para>
  877. </entry>
  878. </row>
  879. </tbody>
  880. </tgroup>
  881. </table>
  882. </sect2>
  883. <sect2 id="zend.date.others.fractions">
  884. <title>Arbeiten mit Sekundenbruchteilen</title>
  885. <para>
  886. Viele Methoden unterstützen es, Werte relativ zu einer <classname>Zend_Date</classname>
  887. Instanz zu erhalten.
  888. </para>
  889. <table id="zend.date.others.fractions.table">
  890. <title>Methoden zur Datumsausgabe</title>
  891. <tgroup cols="2">
  892. <thead>
  893. <row>
  894. <entry>Methode</entry>
  895. <entry>Erklärung</entry>
  896. </row>
  897. </thead>
  898. <tbody>
  899. <row>
  900. <entry>
  901. <para>
  902. <emphasis><methodname>getFractionalPrecision()</methodname></emphasis>
  903. </para>
  904. </entry>
  905. <entry>Gibt die Genauigkeit des Sekundenbruchteils zurück</entry>
  906. </row>
  907. <row>
  908. <entry>
  909. <para>
  910. <emphasis><methodname>setFractionalPrecision()</methodname></emphasis>
  911. </para>
  912. </entry>
  913. <entry>Setzt die Genauigkeit des Sekundenbruchteils</entry>
  914. </row>
  915. </tbody>
  916. </tgroup>
  917. </table>
  918. </sect2>
  919. <sect2 id="zend.date.other.sun">
  920. <title>Sonnenaufgang / Sonnenuntergang</title>
  921. <para>
  922. Drei Methoden geben Zugriff auf geographisch lokalisierte Informationen über die Sonne
  923. was die Zeit für Sonnenaufgang und Sonnenuntergang beinhaltet.
  924. </para>
  925. <table id="zend.date.other.sun.table">
  926. <title>Gewöhliche Methoden</title>
  927. <tgroup cols="2">
  928. <thead>
  929. <row>
  930. <entry>Methode</entry>
  931. <entry>Erklärung</entry>
  932. </row>
  933. </thead>
  934. <tbody>
  935. <row>
  936. <entry>
  937. <para>
  938. <emphasis><methodname>getSunrise($location)</methodname></emphasis>
  939. </para>
  940. </entry>
  941. <entry>Gibt die Zeit des Sonnenaufgangs dieses Datums zurück</entry>
  942. </row>
  943. <row>
  944. <entry>
  945. <para>
  946. <emphasis><methodname>getSunset($location)</methodname></emphasis>
  947. </para>
  948. </entry>
  949. <entry>Gibt die Zeit des Sonnenuntergangs dieses Datums zurück</entry>
  950. </row>
  951. <row>
  952. <entry>
  953. <para>
  954. <emphasis><methodname>getSunInfo($location)</methodname></emphasis>
  955. </para>
  956. </entry>
  957. <entry>Gibt ein Array mit den Sonnendaten des Datums zurück</entry>
  958. </row>
  959. </tbody>
  960. </tgroup>
  961. </table>
  962. </sect2>
  963. </sect1>
  964. <!--
  965. vim:se ts=4 sw=4 et:
  966. -->