Zend_Locale-DatesTimes.xml 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.locale.date.datesandtimes">
  5. <title>Arbeiten mit Daten und Zeiten</title>
  6. <para>
  7. <classname>Zend_Locale_Format</classname> bietet verschiedene Methoden für das Arbeiten mit
  8. Daten und Zeiten und hilft bei der Konvertierung und Normalisierung zwischen verschiedenen
  9. Formaten und verschiedenen Gebietsschemata. Für die Manipulation von Datumszeichenketten die
  10. bereits übereinstimmen mit <link linkend="zend.date.constants">einem der vielen
  11. international erkannten Standardformate, oder einem der lokalisierten Datumsformat welche
  12. von <classname>Zend_Date</classname> verwendet werden</link>. Die Verwendung von
  13. vordefinierten Formate bietet Vorteile, wie die Benutzung von gut getestetem Code, und die
  14. Sicherheit von Beweglichkeit und Interoperabilität (abhängig vom benutzten Standard). Das
  15. unten angeführte Beispiel folgt nicht dieser Empfehlung, da die Benutzung von nicht
  16. standardmäßigen Datumsformaten die Verständlichkeit der Beispiele unnötig erhöhen wurde.
  17. </para>
  18. <sect2 id="zend.locale.date.normalize">
  19. <title>Daten und Zeiten normalisieren</title>
  20. <para>
  21. Die Methode <code>getDate()</code> analysiert Zeichenketten welche Daten in einem
  22. lokalisierten Format enthalten. Das Ergebnis wird als strukturiertes Array zurück
  23. gegeben, mit gut definierten Schlüsseln für jeden Teil des Datums. Zusätzlich enthält
  24. das Array den Schlüssel 'date_format' der den Format String zeigt der benutzt wurde um
  25. die Zeichenkette mit dem Eingabedatum zu analysieren. Da ein lokalisiertes Datum nicht
  26. alle Teile eines Datums oder einer Zeit enthalten muß, sind alle Schüssel Paare des
  27. Arrays optional. Wenn zum Beispiel nur Jahr, Monat und Tag gegeben sind, dann werden
  28. alle Zeit Werte beim zurückgegebenen Array unterdrückt und umgekehrt wenn nur Stunde,
  29. Minute und Sekunde als Eingabe angegeben werden. Wenn weder ein Datum noch eine Zeit in
  30. der Eingabe gefunden werden, dann wird eine Ausnahme geworfen.
  31. </para>
  32. <para>
  33. Wenn <code>setOption(array('fix_date' => true))</code> gesetzt wird, enthält die Methode
  34. <code>getDate()</code> einen Schlüssel 'fixed' der eine Zahl enthält welche anzeigt ob
  35. die eingegebene Zeichenkette korrigiert wurde indem Tag, Monat oder Jahr getauscht
  36. wurden um in das Format zu passen das angegeben wurde.
  37. </para>
  38. <table id="zend.locale.date.normalize.table-1">
  39. <title>Schlüsselwerte für getDate() mit der Option 'fix_date'</title>
  40. <tgroup cols='2'>
  41. <thead>
  42. <row>
  43. <entry>Wert</entry>
  44. <entry>Bedeutung</entry>
  45. </row>
  46. </thead>
  47. <tbody>
  48. <row>
  49. <entry>0</entry>
  50. <entry>Nichts korrigiert</entry>
  51. </row>
  52. <row>
  53. <entry>1</entry>
  54. <entry>Falsches Monat wurde korrigiert</entry>
  55. </row>
  56. <row>
  57. <entry>2</entry>
  58. <entry>Tag und Jahr wurden getauscht</entry>
  59. </row>
  60. <row>
  61. <entry>3</entry>
  62. <entry>Monat und Jahr wurden getauscht</entry>
  63. </row>
  64. <row>
  65. <entry>4</entry>
  66. <entry>Monat und Tag wurden getauscht</entry>
  67. </row>
  68. </tbody>
  69. </tgroup>
  70. </table>
  71. <para>
  72. Für jene die ein spezielles Format für Datumseingaben definieren müssen, werden die
  73. nachfolgend angegebenen Format Zeichen unterstützt. Wenn ein ungültiges Format Zeichen
  74. verwendet wird, so wie PHP's 'i' Zeichen in einem ISO Format, dann wird ein Fehler von
  75. den Methoden, die benutzerdefinierte Formate in
  76. <classname>Zend_Locale_Format</classname> unterstützen, geworfen.
  77. </para>
  78. <para>
  79. Die unten angegebenen Zeichen sind nur ein kleiner Teil des kompletten "ISO" Sets
  80. welches von <classname>Zend_Date</classname>'s <code>toString()</code> unterstützt
  81. werden. Wenn PHP <code>date()</code> kompatible Format Zeichen benutzt werden müssen,
  82. dann muß zuerst <code>setOptions(array('format_type' => 'php'))</code> aufgerufen
  83. werden. Und wenn eine spezielle Format Zeichenkette vom PHP <code>date()</code>
  84. kompatiblen Format in ein "ISO" Format konvertiert werden muß kann
  85. <code>convertPhpToIsoFormat()</code> benutzt werden. Aktuell besteht die einzige
  86. praktische Differenz darin dass das Zeichen für Minuten unterschiedlich ist ('m' wird im
  87. ISO Format und 'i' im PHP date Format verwendet).
  88. </para>
  89. <table id="zend.locale.date.normalize.table-2">
  90. <title>Rückgabewerte</title>
  91. <tgroup cols='5'>
  92. <thead>
  93. <row>
  94. <entry>getDate() Format Zeichen</entry>
  95. <entry>Array Schlüssel</entry>
  96. <entry>Rückgabewert</entry>
  97. <entry>Minimum</entry>
  98. <entry>Maximum</entry>
  99. </row>
  100. </thead>
  101. <tbody>
  102. <row>
  103. <entry>d</entry>
  104. <entry>day</entry>
  105. <entry>Integer</entry>
  106. <entry>1</entry>
  107. <entry>31</entry>
  108. </row>
  109. <row>
  110. <entry>M</entry>
  111. <entry>month</entry>
  112. <entry>Integer</entry>
  113. <entry>1</entry>
  114. <entry>12</entry>
  115. </row>
  116. <row>
  117. <entry>y</entry>
  118. <entry>year</entry>
  119. <entry>Integer</entry>
  120. <entry>kein Limit</entry>
  121. <entry>PHP's Maximum für Integer</entry>
  122. </row>
  123. <row>
  124. <entry>h</entry>
  125. <entry>hour</entry>
  126. <entry>Integer</entry>
  127. <entry>0</entry>
  128. <entry>PHP's Maximum für Integer</entry>
  129. </row>
  130. <row>
  131. <entry>m</entry>
  132. <entry>minute</entry>
  133. <entry>Integer</entry>
  134. <entry>0</entry>
  135. <entry>PHP's Maximum für Integer</entry>
  136. </row>
  137. <row>
  138. <entry>s</entry>
  139. <entry>second</entry>
  140. <entry>Integer</entry>
  141. <entry>0</entry>
  142. <entry>PHP's Maximum für Integer</entry>
  143. </row>
  144. </tbody>
  145. </tgroup>
  146. </table>
  147. <example id="zend.locale.date.normalize.example-1">
  148. <title>Normalisieren von Daten</title>
  149. <programlisting language="php"><![CDATA[
  150. $dateString = Zend_Locale_Format::getDate('13.04.2006',
  151. array('date_format' =>
  152. 'dd.MM.yyyy')
  153. );
  154. // Erstellt ein Zend_Date Objekt für dieses Datum
  155. $dateObject = Zend_Date('13.04.2006',
  156. array('date_format' => 'dd.MM.yyyy'));
  157. print_r($dateString); // Ausgabe
  158. Array
  159. (
  160. [format] => dd.MM.yyyy
  161. [day] => 13
  162. [month] => 4
  163. [year] => 2006
  164. )
  165. // Alternativ können einige Arten von Problemen mit
  166. // den Eingabedaten automatisch korrigiert werden
  167. $date = Zend_Locale_Format::getDate('04.13.2006',
  168. array('date_format' => 'dd.MM.yyyy',
  169. 'fix_date' => true)
  170. );
  171. print_r($date); // Ausgabe
  172. Array
  173. (
  174. [format] => dd.MM.yyyy
  175. [day] => 13
  176. [month] => 4
  177. [year] => 2006
  178. [fixed] => 4
  179. )
  180. ]]></programlisting>
  181. </example>
  182. <para>
  183. Da <code>getDate()</code> "lokalisierbar" ist, ist die Angabe von <code>$locale</code>
  184. ausreichend um Datumseingaben einem Gebietsschema Format zuzuordnen. Die Option
  185. '<code>fix_date</code>' verwendet einfache Tests um herauszufinden ob Tag oder Monat
  186. ungültig sind, um dann eine Heuristik anzuwenden die versucht alle gefundenen Probleme
  187. zu korrigieren. Anzumerken ist auch die Verwendung von
  188. '<classname>Zend_Locale_Format::STANDARD</classname>' als Wert für
  189. '<code>date_format</code>' bei der Funktion <code>setOptions()</code> um zu verhindern
  190. das das klassenweit gesetzte standardmäßige Datumsformat verwendet wird. Das zwingt
  191. getDate dazu das standardmäßige Datumsformat dieser <code>$locale</code> zu verwenden.
  192. </para>
  193. <example id="zend.locale.date.normalize.example-2">
  194. <title>Normalisieren eines Datums durch ein Gebietsschema</title>
  195. <programlisting language="php"><![CDATA[
  196. $locale = new Zend_Locale('de_AT');
  197. $date = Zend_Locale_Format::getDate('13.04.2006',
  198. array('date_format' =>
  199. Zend_Locale_Format::STANDARD,
  200. 'locale' => $locale)
  201. );
  202. print_r ($date);
  203. ]]></programlisting>
  204. </example>
  205. <para>
  206. Ein komplettes Datum mit Uhrzeit wird zurückgegeben, wenn die Eingabe beides, ein Datum
  207. und eine Uhrzeit, um erwarteten Format enthält.
  208. </para>
  209. <example id="zend.locale.date.normalize.example-3">
  210. <title>Normalisieren eines Datums mit Uhrzeit</title>
  211. <programlisting language="php"><![CDATA[
  212. $locale = new Zend_Locale('de_AT');
  213. $date = Zend_Locale_Format::getDate('13.04.2005 22:14:55',
  214. array('date_format' =>
  215. Zend_Locale_Format::STANDARD,
  216. 'locale' => $locale
  217. );
  218. print_r ($date);
  219. ]]></programlisting>
  220. </example>
  221. <para>
  222. Wenn ein spezielles Format gewünscht ist, muß das <code>$format</code> Argument
  223. definiert werden, ohne der Angabe von <code>$locale</code>. Nur die einzelnen Zeichen
  224. (H, m, s, y, M, d), und MMMM und EEEE werden bei <code>$format</code> unterstützt.
  225. </para>
  226. <example id="zend.locale.date.normalize.example-4">
  227. <title>Normalisieren eines Benutzerdefinierten Datums</title>
  228. <programlisting language="php"><![CDATA[
  229. $date = Zend_Locale_Format::getDate('13200504T551422',
  230. array('date_format' =>
  231. 'ddyyyyMM ssmmHH')
  232. );
  233. print_r ($date);
  234. ]]></programlisting>
  235. </example>
  236. <para>
  237. Ein Format kann die folgenden Zeichen enthalten:
  238. </para>
  239. <table id="zend.locale.date.normalize.table-3">
  240. <title>Format Definition</title>
  241. <tgroup cols='2'>
  242. <thead>
  243. <row>
  244. <entry>Format Buchstabe</entry>
  245. <entry>Beschreibung</entry>
  246. </row>
  247. </thead>
  248. <tbody>
  249. <row>
  250. <entry>d oder dd</entry>
  251. <entry>Tag mit 1 oder 2 Ziffern</entry>
  252. </row>
  253. <row>
  254. <entry>M oder MM</entry>
  255. <entry>Monat mit 1 oder 2 Ziffern</entry>
  256. </row>
  257. <row>
  258. <entry>y oder yy</entry>
  259. <entry>Jahr mit 1 or 2 Ziffern</entry>
  260. </row>
  261. <row>
  262. <entry>yyyy</entry>
  263. <entry>Jahr mit 4 Ziffern</entry>
  264. </row>
  265. <row>
  266. <entry>h</entry>
  267. <entry>Stunde mit 1 oder 2 Ziffern</entry>
  268. </row>
  269. <row>
  270. <entry>m</entry>
  271. <entry>Minute mit 1 oder 2 Ziffern</entry>
  272. </row>
  273. <row>
  274. <entry>s</entry>
  275. <entry>Sekunde mit 1 oder 2 Ziffern</entry>
  276. </row>
  277. </tbody>
  278. </tgroup>
  279. </table>
  280. <para>
  281. Beispiele für gültige Formate sind
  282. </para>
  283. <table id="zend.locale.date.normalize.table-4">
  284. <title>Beispielformate</title>
  285. <tgroup cols='3'>
  286. <thead>
  287. <row>
  288. <entry>Formate</entry>
  289. <entry>Eingabe</entry>
  290. <entry>Ausgabe</entry>
  291. </row>
  292. </thead>
  293. <tbody>
  294. <row>
  295. <entry>dd.MM.yy</entry>
  296. <entry>1.4.6</entry>
  297. <entry>['day'] => 1,
  298. ['month'] => 4,
  299. ['year'] => 6</entry>
  300. </row>
  301. <row>
  302. <entry>dd.MM.yy</entry>
  303. <entry>01.04.2006</entry>
  304. <entry>['day'] => 1, ['month'] => 4, ['year'] => 2006</entry>
  305. </row>
  306. <row>
  307. <entry>yyyyMMdd</entry>
  308. <entry>1.4.6</entry>
  309. <entry>['day'] => 6, ['month'] => 4, ['year'] => 1</entry>
  310. </row>
  311. </tbody>
  312. </tgroup>
  313. </table>
  314. <note>
  315. <title>Datumsformate für Datenbanken</title>
  316. <para>
  317. Um einen Datumswert einer Datenbank zu analysieren (zum Beispiel MySql oder MsSql)
  318. sollte <classname>Zend_Date</classname>'s ISO_8601 Format statt getDate() benutzt
  319. werden.
  320. </para>
  321. </note>
  322. <para>
  323. Die Option '<code>fix_date</code>' benutzt einfache Tests um herauszufinden ob der Tag
  324. oder das Monat ungültig sind, und wendet dann eine Heuristik an die versucht die
  325. erkannten Probleme zu beheben. <code>getDate()</code> erkennt und behebt automatisch
  326. einige Problem mit falschen Eingabe, wie zum Beispiel ein falsch plaziertes Jahr:
  327. </para>
  328. <example id="zend.locale.date.normalize.example-5">
  329. <title>Automatische Korrektur von Datumsangaben</title>
  330. <programlisting language="php"><![CDATA[
  331. $date = Zend_Locale_Format::getDate('41.10.20',
  332. array('date_format' => 'ddMMyy',
  333. 'fix_date' => true)
  334. );
  335. // Statt 41 für den Tag wird die 41 als Wert für das Jahr zurück gegeben
  336. print_r ($date);
  337. ]]></programlisting>
  338. </example>
  339. </sect2>
  340. <sect2 id="zend.locale.date.test">
  341. <title>Testen von Daten</title>
  342. <para>
  343. <code>checkDateFormat($inputString, array('date_format' => $format, $locale))</code>
  344. kann benutzt werden um zu prüfen ob eine Zeichenkette alle erwarteten Datumsteile
  345. enthält. Die Methode <code>checkDateFormat()</code> benutzt <code>getDate()</code> aber
  346. ohne die Verwendung der Option <code>'fixdate'</code> um zu verhindern das wahr zurück
  347. gegeben wird wenn die Eingabe nicht dem Datumsformat entspricht. Wenn Fehler in der
  348. Eingabe gefunden werden, wie zum Beispiel getauschte Werte für Monat oder Jahr, wendet
  349. die Option <code>'fixdate'</code> eine Heuristik an um das "richtige" Datum zu eruieren
  350. bevor dieses auf Gültigkeit geprüft wird.
  351. </para>
  352. <example id="zend.locale.date.test.example-1">
  353. <title>Testen von Daten</title>
  354. <programlisting language="php"><![CDATA[
  355. $locale = new Zend_Locale('de_AT');
  356. // Standard Datumsformate für 'de_AT' benutzen... ist es ein gültiges Datum ?
  357. if (Zend_Locale_Format::checkDateFormat('13.Apr.2006',
  358. array('date_format' =>
  359. Zend_Locale_Format::STANDARD,
  360. $locale)
  361. ) {
  362. print "Datum";
  363. } else {
  364. print "kein Datum";
  365. }
  366. ]]></programlisting>
  367. </example>
  368. </sect2>
  369. <sect2 id="zend.locale.time.normalizing">
  370. <title>Normalisieren von Zeiten</title>
  371. <para>
  372. Normalerweise werden Zeiten zusammen mit einem Datum zurückgegeben, wenn die Eingabe
  373. beide Werte enthält. Wenn das richtige Format nicht bekannt ist, aber das Gebietsschema
  374. für die Eingabe des Benutzers bekannt ist, sollte <code>getTime()</code> verwendet
  375. werden, weil es das standardmäßige Zeitformat für das ausgewählte Gebietsschema benutzt.
  376. </para>
  377. <example id="zend.locale.time.normalizing.example-1">
  378. <title>Normalisieren einer unbekannten Zeit</title>
  379. <programlisting language="php"><![CDATA[
  380. $locale = new Zend_Locale('de_AT');
  381. if (Zend_Locale_Format::getTime('13:44:42',
  382. array('date_format' =>
  383. Zend_Locale_Format::STANDARD,
  384. 'locale' => $locale)
  385. ) {
  386. print "Zeit";
  387. } else {
  388. print "keine Zeit";
  389. }
  390. ]]></programlisting>
  391. </example>
  392. </sect2>
  393. <sect2 id="zend.locale.time.test">
  394. <title>Testen von Zeiten</title>
  395. <para>
  396. <code>checkDateFormat()</code> kann verwendet werden um zu prüfen ob eine Zeichenkette
  397. eine gültige Zeit enthält. Die Verwendung ist genau die gleiche wie beim Prüfen von
  398. Daten und <code>date_format</code> sollte die Teile enthalten von denen erwartet wird
  399. das man Sie erhält.
  400. </para>
  401. <example id="zend.locale.time.test.example-1">
  402. <title>Testen einer Zeit</title>
  403. <programlisting language="php"><![CDATA[
  404. $locale = new Zend_Locale('de_AT');
  405. if (Zend_Locale_Format::checkDateFormat('13:44:42',
  406. array('date_format' => 'HH:mm:ss',
  407. 'locale' => $locale)) {
  408. print "Zeit";
  409. } else {
  410. print "keine Zeit";
  411. }
  412. ]]></programlisting>
  413. </example>
  414. </sect2>
  415. </sect1>