Zend_Locale verwenden

Normalisierung und Lokalisierung

Zend_Locale_Format ist eine interne Komponente, welche von Zend_Locale verwendet wird. Alle lokalisierbaren Klassen benutzen Zend_Locale_Format für Normalisierung und Lokalisierung von Nummern und Daten. Normalisierung beinhaltet das Analysieren von Eingaben von einer Vielfalt von Werten wie Datumswerten in eine standardisierte, strukturieren Art wie zum Beispiel ein PHP Array mit Jahr, Monat und Tages Elementen.

Genau die gleiche Zeichenkette, die eine Zahl oder ein Datum enthält, kann verschiedenes bedeuten für Leute mit unterschiedlichen Gebräuchen und Konventionen. Das Auflösen von Mehrdeutigkeiten von Nummern und Daten benötigt Regeln darüber, wie diese Zeichenketten zu interpretieren sind um diese Werte in eine standardisierte Form zu bringen. Deswegen benötigen alle Methoden in Zend_Locale_Format ein Gebietsschema, um Eingabedaten analysieren zu können.

Note: Standard "root" Gebietsschema
Wenn kein Gebietsschema spezifiziert wurde, wird die Normalisierung und Lokalisierung das Standard "root" Gebietsschema verwenden, was zu unerwarteten Ergebnissen führen kann, wenn die Eingabe in einem anderen Gebietsschema angegeben oder die Ausgabe für ein anderes Gebietsschema erwartet wurde.

Normalisierung von Zahlen: getNumber($input, Array $options)

Es gibt viele » Ziffernsysteme, welche sich vom üblichen » Dezimalsystem unterscheiden (z.B. "3.14"). Zahlen können mit der Funktion getNumber() normalisiert werden, um ein gleichwertiges Ergebnis in einer Schreibweise des Standarddezimalsystems zu erhalten. Für alle Ziffern-relevanten Diskussionen in diesem Handbuch werden die » Arabisch/Europäischen Ziffern (0,1,2,3,4,5,6,7,8,9) verwendet, ausser es ist anders definiert. Das Options-Array kann ein 'locale'.Gebietsschema enthalten, um eine Gruppierung und Kommazeichen zu definieren. Das Array kann auch eine Genauigkeit 'precision' enthalten, um überschüssige Ziffern vom Ergebnis abzuschneiden.

Example #1 Normalisieren von Zahlen

  1. span style="color: #ff0000;">'de_AT''13.524,678''locale' => $locale,
  2.                                               'precision'// wird 13524.678 zurückgeben

Genauigkeit und Berechnungen

Da getNumber($value, array $options = array()) extrem große Zahlen lokalisieren kann, sollte das Ergebnis sorgfältig geprüft werden, bevor endlich genaue Berechnungen wie normale mathematische PHP Operationen gemacht werden. Zum Beispiel if ((string)int_val($number) != $number) { benutze » BCMath oder » GMP. Die meisten PHP Installationen unterstützen die BCMath Erweiterung.

Auch die Genauigkeit des dezimalen Ergebnisses bei getNumber() kann mit der Option'precision' 'precision' zu einer gewünschten Länge abgerundet werden. Wenn keine Genauigkeit angegeben wurde, wird nicht abgerundet. Für die Angabe der Genauigkeit dürfen nur PHP Integer Zahlen verwendet werden. Das Ergebnis wird nicht gerundet. Deswegen wird "1.6" auch "1" und nicht "2" zurückgeben, wenn als Genauigkeit null angegeben wurde.

Wenn das dezimale Ergebnis zu einer gewünschten Länge abgeschnitten statt gerundet werden soll kann stattdessen die Option 'number_format' verwendet werden. Die Länge des gewünschten dezimalen Ergebnisses kann mit der gewünschten Länge von Nullen bestimmt werden. Das Ergebnis wird dann nicht gerundet. Wenn also die definierte Genauigkeit innerhalb von number_format Null ist wird "1.6" den Wert "1" und nicht "2" zurückgeben. Siehe das folgende Beispiel:

Example #2 Normalisierung von Zahlen mit Genauigkeit

  1. span style="color: #ff0000;">'de_AT''13.524,678''precision' => 1,
  2.                                               'locale'// will 13524.7 zurückgeben
  3. '13.524,678''number_format' => '#.00',
  4.                                               'locale'// will 13524.67 zurückgeben

Lokalisieren von Zahlen

toNumber($value, array $options = array()) kann mit Hilfe der folgenden unterstützten Gebietsschemata, Zahlen lokalisieren. Diese Funktion gibt eine lokalisierte Zeichenkette der angegebenen Zahl in dem konventionellen Format für ein definiertes Gebietsschema aus. Die Option 'number_format' definiert ein explizit angegebenes, nicht standardmäßiges Zahlenformat für die Verwendung mit toNumber().

Example #3 Lokalisieren von Zahlen

  1. span style="color: #ff0000;">'de_AT''locale' => $locale));
  2.  
  3. // gibt 13.547,36 zurück

Note: Unlimitierte Länge
toNumber() kann Zahlen mit unendlicher Länge lokalisieren. Hierbei gibt es keine Abhängigkeiten mit Integer oder Float Limits.

Genauso wie getNumber() verwendet toNumber() die Genauigkeit. Wenn keine Genauigkeit angegeben wurde, wird die komplette lokalisierte Zahl zurückgegeben.

Example #4 Zahlen mit bestimmter Genauigkeit lokalisieren

  1. span style="color: #ff0000;">'de_AT''precision' => 2,
  2.                                              'locale' => $locale));
  3.  
  4. // gibt 13.547,37 zurück

Wird die Option 'number_format' benutzt, kann ein selbst definiertes Format für das erstellen der Zahl definiert werden. Das Format selbst muß im CLDR Format wie anbei beschrieben angegeben werden. Das Gebietsschema wird hierbei benutzt um das Trennzeichen, die Genauigkeit und andere Formatierungszeichen für Zahlen zu erhalten. Deutsch definiert zum Beispiel ',' als Kommazeichen und im Englischen wird das '.' Zeichen benutzt.

Definitionen für selbst erzeugte Zahlenformate
Definition Beschreibung Beispiel Format Erzeugte Ausgabe
#0 Erzeugt eine Zahl ohne Genauigkeit und ohne Trennung #0 1234567
, Erzeugt eine Trennung mit der Länge von einem Trennzeichen zum nächsten oder zur 0 #,##0 1,234,567
#,##,##0 Erzeugt eine Standardtrennung von 3 und alle weiteren Trennungen mit 2 #,##,##0 12,34,567
. Erzeugt eine Kommazahl #0.# 1234567.1234
0 Erzeugt eine Kommazahl mit definierter Länge #0.00 1234567.12

Example #5 Ein selbst definiertes Zahlenformat verwenden

  1. span style="color: #ff0000;">'de_AT''number_format' => '#,#0.00',
  2.                                              'locale' => 'de')
  3.                                       );
  4.  
  5. // gibt 1.35.47,36 zurück
  6. 'number_format' => '#,##0.00',
  7.                                              'locale' => 'de')
  8.                                       );
  9.  
  10. // gibt 13.547,30 zurück

Testen von Zahlen

isNumber($value, array $options = array()) prüft, ob eine gegebene Zeichenkette eine Zahl enthält und gibt TRUE oder FALSE zurück.

Example #6 Testen von Zahlen

  1. span style="color: #ff0000;">'13.445,36''locale' => 'de_AT'"Zahl""keine Zahl";
  2. }

Gleitkommazahlen normalisieren

Lokalisierte Gleitkommazahlen können mit getFloat($value, array $options = array()) analysiert werden. Es wird eine Gleitkommazahl zurückgegeben.

Example #7 Gleitkommazahlen normalisieren

  1. span style="color: #ff0000;">'de_AT''13.524,678''precision' => 2,
  2.                                              'locale' => $locale));
  3.  
  4. // gibt 13524.68 zurück

Lokalisieren von Gleitkommazahlen

toFloat() kann Gleitkommazahlen lokalisieren. Diese Funktion gibt eine lokalisierte Zeichenkette mit der gegebenen Zahl zurück.

Example #8 Lokalisieren von Gleitkommazahlen

  1. span style="color: #ff0000;">'de_AT''precision' => 1,
  2.                                             'locale' => $locale));
  3.  
  4. // gibt 13.547,4 zurück

Testen von Gleitkommazahlen

isFloat($value, array $options = array()) prüft, ob eine gegebene Zeichenkette eine Gleitkommazahl enthält und gibt TRUE oder FALSE zurück.

Example #9 Testen von Gleitkommazahlen

  1. span style="color: #ff0000;">'de_AT''13.445,36''locale'"Gleitkommazahl""keine Gleitkommazahl";
  2. }

Integer-Zahlen normalisieren

Ganzzahlen können mit der Funktion getInteger() analysiert werden. Es wird ein Ganzzahlwert (Integer) zurückgegeben.

Example #10 Normalisieren von Integer-Zahlen

  1. span style="color: #ff0000;">'de_AT''13.524,678''locale' => $locale));
  2.  
  3. // gibt 13524 zurück

Lokalisieren von Ganzzahlen

toInteger($value, array $options = array()) kann Integer-Zahlen lokalisieren. Diese Funktion gibt eine lokalisierte Zeichenkette anhand der gegebenen Nummer zurück.

Example #11 Lokalisieren von Integer-Zahlen

  1. span style="color: #ff0000;">'de_AT''locale' => $locale));
  2.  
  3. // gibt 13.547 zurück

Testen von Integer-Zahlen

isInteger($value, array $options = array()) prüft ob eine gegebene Zeichenkette eine Ganzzahl enthält und gibt TRUE oder FALSE zurück.

Example #12 Testen von Integer-Zahlen

  1. span style="color: #ff0000;">'de_AT''13.445''locale'"Integerzahl""keine Integerzahl";
  2. }

Konvertieren von Zahlensystemen

Zend_Locale_Format::convertNumerals() kann die Ziffern zwischen den unterschiedlichen » Zahlensystemen umwandeln. Das inkludiert auch das Standard Arabisch/Europäisch/Lateinische Zahlensystem (0,1,2,3,4,5,6,7,8,9). Nicht zu verwechseln mit dem » Ost-arabischen Zahlensystem, welches in der Arabischen Sprache benutzt wird, um Zahlen zu schreiben. Der Versuch, ein nicht unterstütztes Zahlensystem zu benutzen, führt zu einer Ausnahme, um eine irrtümliche falsche Konvertierung wegen eines Schreibfehlers zu verhindern. Alle Zeichen der Eingabe, welche keine Ziffern des angegebenen Zahlenformates sind, werden in den Ausgabestring kopiert ohne dass sie verändert werden. Das beinhaltet auch die Trennzeichen der Zahlen. Zend_Locale* Komponenten sind abhängig von den Daten, welche durch CLDR zur Verfügung gestellt werden (hier ist eine » Liste von Schreibweisen gruppiert nach Sprachen).

Im CLDR und auch hier, werden die Europäisch/Lateinischen Zahlen als "Latin" oder mit dem zugeordneten 4-Zeichen-Code "Latn" bezeichnet. Im CLDR werden Zahlensysteme auch als "Schreibweisen" (Scripts) bezeichnet.

Nehmen wir an eine Web-Form erhält eine numerische Eingabe, welche Ost-Arabische Ziffern enthält "١‎٠٠". Die meisten Programme und PHP-Funktionen erwarten Eingaben aber als Lateinische Ziffern. Glücklicherweise ist die Konvertierung dieser Eingabe in gleichwertige Lateinische Ziffern "100" sehr wenig Aufwand. Es muss nur convertNumerals($inputNumeralString, $sourceNumeralSystem, $destNumeralSystem) benutzt werden, welches $input zurückgibt und hierbei die Ziffern der Schreibweise $sourceNumeralSystem in die Schreibweise $destNumeralSystem konvertiert.

Example #13 Konvertieren von Ost-Arabischen Ziffern in Europäisch-Lateinische Ziffern

  1. $arabicScript = "١‎٠٠";   // Arabisch für "100" (ein Hundert)
  2. 'Arab',
  3.                                                    'Latn'"\nOriginal:   ""\nNormalisiert: " . $latinScript;

Genauso kann jedes unterstützte Zahlensystem in jedes andere unterstützte Zahlensystem konvertiert werden.

Example #14 Konvertieren von Lateinischen Ziffern in Ost-Arabische Ziffern

  1. $latinScript = '123''Latn',
  2.                                                     'Arab'"\nOriginal:  ""\nLokalisiert: " . $arabicScript;

Example #15 Auslesen des 4 Zeichen CLDR Codes durch Benutzen des Namens in der Muttersprache

  1. span style="color: #ff0000;">'scriptlist''Latin', 'en'); // Ausgabe "Latn"
  2. 'Tamil', 'en'); // Ausgabe "Taml"
  3. 'tamoul', 'fr'); // Ausgabe "Taml"

Für eine Liste der unterstützten Zahlensysteme kann man Zend_Locale::getTranslationList('numberingsystem', 'en') aufrufen.


Zend_Locale verwenden