Normalizer クラス

はじめに

正規化とは、文字や文字列を正式に決められた表現に変換する処理のことです。 これは、検索や並べ替えなどの際に比較をするときに特に重要となります。 ただ、それだけではなく、テキストを保存する際に表記を統一するために用いることもあります。

Unicode Consortium では、 アプリケーション側でのさまざまなニーズにあわせていくつかの正規化方式を定義しています。

  • Normalization Form D (NFD) - Canonical Decomposition
  • Normalization Form C (NFC) - Canonical Decomposition followed by Canonical Composition
  • Normalization Form KD (NFKD) - Compatibility Decomposition
  • Normalization Form KC (NFKC) - Compatibility Decomposition followed by Canonical Composition
これらの方式は、テキストに対する変換 (transformation) のセットとして定義されます。変換 (transformation) は、アルゴリズムとデータファイルの両方で表現します。

クラス概要

Normalizer
/* 定数 */
public const int Normalizer::FORM_D;
public const int Normalizer::NFD;
public const int Normalizer::FORM_KD;
public const int Normalizer::NFKD;
public const int Normalizer::FORM_C;
public const int Normalizer::NFC;
public const int Normalizer::FORM_KC;
public const int Normalizer::NFKC;
public const int Normalizer::FORM_KC_CF;
public const int Normalizer::NFKC_CF;
/* メソッド */
public static stringnull getRawDecomposition(string $string, int $form = Normalizer::FORM_C)
public static bool isNormalized(string $string, int $form = Normalizer::FORM_C)
public static stringfalse normalize(string $string, int $form = Normalizer::FORM_C)

定義済み定数

以下の定数は、使用する正規化方式を定義するものです。

Normalizer::FORM_C
Normalization Form C (NFC) - Canonical Decomposition followed by Canonical Composition
Normalizer::FORM_D
Normalization Form D (NFD) - Canonical Decomposition
Normalizer::NFD

Normalizer::FORM_KC
Normalization Form KC (NFKC) - Compatibility Decomposition, followed by Canonical Composition
Normalizer::NFKC

Normalizer::FORM_KC_CF

Normalizer::FORM_KD
Normalization Form KD (NFKD) - Compatibility Decomposition
Normalizer::NFKD

Normalizer::NFC

Normalizer::NFKC_CF

変更履歴

バージョン 説明
8.0.0 Normalizer::NONE が削除されました。
目次