Zend_Date-Overview.xml 55 KB

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