名稱空間
變體
操作

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 區域設定的時間格式類別

locale.h 中可以定義其他以 LC_ 開頭並後跟至少一個大寫字母的宏常量。例如,POSIX 規範要求 LC_MESSAGES(它控制 perrorstrerror 等),ISO/IEC 30112:2014 (2014 草案) 還定義了 LC_IDENTIFICATIONLC_XLITERATELC_NAMELC_ADDRESSLC_TELEPHONELC_PAPERLC_MEASUREMENTLC_KEYBOARD,這些都受 GNU C 庫支援(除了 LC_XLITERATE)。

[編輯] 示例

#include <locale.h>
#include <stdio.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: 金曜日 2023年09月15日 20時04分14秒

[編輯] 參考文獻

  • C23 標準 (ISO/IEC 9899:2024)
  • 7.11/3 本地化 <locale.h> (p: 待定)
  • C17 標準 (ISO/IEC 9899:2018)
  • 7.11/3 本地化 <locale.h> (p: 待定)
  • C11 標準 (ISO/IEC 9899:2011)
  • 7.11/3 本地化 <locale.h> (p: 224)
  • C99 標準 (ISO/IEC 9899:1999)
  • 7.11/3 本地化 <locale.h> (p: 205)
  • C89/C90 標準 (ISO/IEC 9899:1990)
  • 4.4 本地化 <locale.h>

[編輯] 另請參見

獲取和設定當前 C 區域設定
(函式) [編輯]
C++ 文件,關於 區域設定類別