Go to main content
Oracle® Solaris 11.3 国際化対応言語環境の利用ガイド

印刷ビューの終了

更新: 2016 年 11 月
 
 

ロケールの影響を受ける動作

数値を書式設定したり、日付や時間を記述したり、単語や語句を区切ったり、書かれたり話されたりした資料を引用したりする際に使用される表記規則は通常、文化ごとに異なります。ロケールは、次の処理、ファイル、書式、および表現をさまざまな地域で処理する方法を決定します。

  • テキストデータのエンコードや処理

  • リソースファイルの言語識別やエンコード

  • テキスト文字列のレンダリングやレイアウト

  • クライアント間でのテキストの交換

  • 選択された文字のコードセットやテキスト処理の要件に合う入力方式の選択

  • 文化的に固有のフォントやアイコンファイル

  • ユーザーインタフェース定義 (UID) ファイル

  • 日付や時間の書式

  • 数値の書式

  • 通貨の書式

  • 照合順序

  • 正規表現の処理

  • 情報メッセージや診断メッセージおよび対話式応答の書式

Oracle Solaris 環境は、言語や文化に依存する情報をアプリケーションから分離し、その情報をアプリケーションの外側に保存します。この方法を使えば、アプリケーションの変換、書き換え、または再コンパイルをマーケットごとに行う必要がなくなります。新しいマーケットに参入するのに必要なのは、外部情報をローカルの言語や慣例にローカライズすることだけです。

以降のセクションでは、ロケールカテゴリごとに存在する言語間の違いや、その他の言語間の違いについて説明します。

時間の書式

次の表に、さまざまなロケールでの 11:59 P.M の出力方法をいくつか示します。現在のロケールでの時間の書式を表示するには、次のコマンドを発行します。

$ date +%X
表 2  時間の国際書式
ロケール
説明
時間の書式
C
-
23:59:00
en_US.UTF-8
英語、米国
11:59:00 PM
es_US.UTF-8
スペイン語、米国
11:59:00 p.m.
mr_IN.UTF-8
マラーティー語、インド
11-59-00 pm
sq_AL.ISO8859-2
アルバニア語、アルバニア
11.59.00.MD
ja_JP.UTF-8
日本語、日本
23時59分00秒
ko_KR.UTF-8
韓国語、韓国
오후11시 59분 00초
zh_CN.UTF-8
簡体字中国語、中国
23时59分00秒

時間は 12 時間形式、24 時間形式のどちらでも表せます。時間と分の区切り文字は、コロン ( : )、ピリオド ( . )、ダッシュ ( - ) のいずれかになります。

タイムゾーンの分割は、国と国との間や国内で発生します。タイムゾーンは、協定世界時 UTC (またはグリニッジ標準時 GMT) から何時間進んでいるか、あるいは何時間遅れているかによって記述できますが、その数値は常に整数になるとは限りません。たとえば、ニューファンドランド島が含まれるタイムゾーンと隣接するタイムゾーンとの時差は、0.5 時間です。

夏時間 (DST) の開始と終了の日付は、国ごとに異なる可能性があります。多くの国では DST をまったく実施しません。さらに、1 つのタイムゾーン内で夏時間が異なる場合があります。たとえば米国では、実施の決定権は州にあります。

日付の書式

次の表に、世界中で使用されている日付の書式をいくつか示します。1 つの国のなかでも違いが存在する場合があります。現在のロケールでの日付の書式を表示するには、次のコマンドを発行します。

$ date +%x
表 3  日付の国際書式
ロケール
説明
日付の書式
C
-
07/16/11
en_CA.UTF-8
英語、カナダ
7/11/16
en_GB.UTF-8
英語、英国
7/16/11
fi_FI.UTF-8
フィンランド語、フィンランド
7/16/11
ja_JP.UTF-8
日本語、日本
2011年07月16日
ko_KR.UTF-8
韓国語、韓国
2011년07월16일
zh_TW.UTF-8
繁体字中国語、台湾
11年07月16日

数値の書式

ロケールによって指定される数値書式にはさまざまなものが存在しています。たとえば、英国と米国では、ピリオドを使って小数位を示します。ほかの多くの国では、代わりにコンマを使用します。小数区切り文字は基数文字とも呼ばれます。同様に、英国と米国ではコンマを使って千のグループを区切りますが、ほかの多くの国では代わりにピリオドを使用しますし、一部の国では千のグループを細い空白 (Unicode 文字 U+2009) で区切ります。

ロケール固有の書式を含むデータファイルを異なるロケールのシステムに転送した場合、その内容の解釈ミスが頻繁に発生します。たとえば、フランス語の書式の数値を含むファイルは、英国に固有のプログラムでは役に立ちません。

次の表に、一般的に使用される数値書式をいくつか示します。現在のロケールでの数値区切り文字の情報を取得するには、次のコマンドを発行します。

$ locale -ck LC_NUMERIC
表 4  数値の国際表記規則
ロケール
説明
数値の書式
C
-
4294967.00
ar_SA.UTF-8
アラビア語、サウジアラビア
4967967,00
cs_CZ.UTF-8
チェコ語、チェコ共和国
4 294 967,00
de_DE.UTF-8
ドイツ語、ドイツ
4.294.967,00
de_CH.UTF-8
ドイツ語、スイス
4'294'967.00
en_US.UTF-8
英語、米国
4,294,967.00
hi_IN.UTF-8
ヒンズー語、インド
42,94,967.00

注 - リスト内の数値を区切る方法を指定するロケール表記規則は、特に存在していません。

通貨の国際書式

通貨の通貨単位、表示順序、およびローカル記号や国際記号は、世界中で大きく異なります。現在のロケールの通貨書式を取得するには、次のコマンドを発行します。

$ locale -ck LC_MONETARY

次の表に、いくつかの国の通貨書式を示します。

表 5  通貨の国際表記規則
ロケール
通貨
C
-
1234.56
da_DK.UTF-8
デンマーククローネ (kr)
1.234,56kr
da_DK.ISO8859-15@euro
ユーロ (EUR)
1.234,56€
en_GB.UTF-8
ポンド (£)
£1,234.56
en_US.UTF-8
米国ドル ($)
$1,234.56
fr_FR.UTF-8
ユーロ (EUR)
1 234,56€
ja_JP.UTF-8
日本円 (¥)
¥1,235
th_TH.UTF-8
タイ・バーツ (THB)
฿1,234.56
zh_CN.UTF-8
中国元 (¥)
¥1,234.56

ユーロ通貨はすべての UTF-8 ロケールでサポートされています。また、ISO8859-15 コードセットに基づくレガシーロケールも使用可能となっており、ユーロを自国通貨として採用したなかった国向けに、(da_DK.ISO8859-15@euro のように) @euro バリアント付きで存在しています。