名前空間
変種
操作

LC_ALL, LC_COLLATE, LC_CTYPE, LC_MONETARY, LC_NUMERIC, LC_TIME

提供: cppreference.com
< c‎ | locale
ヘッダ <locale.h> で定義
#define LC_ALL      /*implementation defined*/
#define LC_COLLATE  /*implementation defined*/
#define LC_CTYPE    /*implementation defined*/
#define LC_MONETARY /*implementation defined*/
#define LC_NUMERIC  /*implementation defined*/
#define LC_TIME     /*implementation defined*/

上記のマクロ定数は setlocale の最初の引数として使用するために適したそれぞれ異なる値を持つ整数定数式に展開されます。

定数 説明
LC_ALL C のロケール全体を選択します
LC_COLLATE C のロケールの照合カテゴリを選択します
LC_CTYPE C のロケールの文字分類カテゴリを選択します
LC_MONETARY C のロケールの金額書式化カテゴリを選択します
LC_NUMERIC C のロケールの数値書式化カテゴリを選択します
LC_TIME C のロケールの時間書式化カテゴリを選択します

LC_ で始まり少なくとも1個の大文字が続く名前の追加のマクロ定数が <locale.h> で定義されるかもしれません。 例えば、 POSIX の仕様は LC_MESSAGES (特に std::perrorstd::strerror を制御します) を要求し、 ISO/IEC 30112:2014 (2014 draft) はさらに LC_IDENTIFICATION, LC_XLITERATE, LC_NAME, LC_ADDRESS, LC_TELEPHONE, LC_PAPER, LC_MEASUREMENT, LC_KEYBOARD を定義しています (LC_XLITERATE 以外は GNU C ライブラリでサポートされています)。

[編集]

#include <stdio.h>
#include <locale.h>
#include <time.h>
#include <wchar.h>
 
int main(void)
{
    setlocale(LC_ALL, "en_US.UTF-8"); // the C locale will be the UTF-8 enabled English
    setlocale(LC_NUMERIC, "de_DE.utf8");   // decimal dot will be German
    setlocale(LC_TIME, "ja_JP.utf8");      // date/time formatting will be Japanese
    wchar_t str[100];
    time_t t = time(NULL);
    wcsftime(str, 100, L"%A %c", localtime(&t));
    wprintf(L"Number: %.2f\nDate: %Ls\n", 3.14, str);
}

出力例:

Number: 3,14
Date: 月曜日 2017年09月25日 13時00分15秒

[編集] 参考文献

  • C11 standard (ISO/IEC 9899:2011):
  • 7.11/3 Localization <locale.h> (p: 224)
  • C99 standard (ISO/IEC 9899:1999):
  • 7.11/3 Localization <locale.h> (p: 205)
  • C89/C90 standard (ISO/IEC 9899:1990):
  • 4.4 LOCALIZATION <locale.h>

[編集] 関連項目

現在のCのロケールを取得および設定します
(関数) [edit]
ロケールカテゴリC++リファレンス