C# 标准数字格式字符串

总目录


前言

当前文章为 C# 中的格式设置(格式化字符串) 大全 中的一个小章节。


一、概述

1. 基本信息

  • 标准数字格式字符串用于格式化通用数值类型。
  • 标准数字格式字符串采用 [format specifier][precision specifier] 的形式
    • format specifier 格式说明符,负责指定数字格式类型,通常是单个字母字符,如G、C、F等
    • precision specifier 精度说明符,负责控制数字的字符串表示形式中的数字个数。是一个可选整数,它影响生成的字符串中的位数
      • 在 .NET 7 及更高版本中,最大精度值为 999,999,999。
      • 在 .NET 6 中,最大精度值为 Int32.MaxValue
      • 在旧版 .NET 中,精度范围可以为 0 到 99。
    • 当精度说明符控制结果字符串中的小数位数时,在格式化时会进行四舍五入运算后返回结果
      • 标准数字格式字符串 在做精度控制的时候,基本都会在格式化时进行四舍五入
        static void Main(string[] args){double amount = 1234.5678;Console.WriteLine(amount.ToString("C"));   // 输出: ¥1,234.57Console.WriteLine(amount.ToString("C3"));  // 输出: ¥1,234.568}

如上面的案例中的C3

  • C 是 格式说明符,指定的数据格式类型为 货币
  • 3 是 精度说明符,负责控制结果字符串的小数位,指定为3位
  • 3 控制了结果字符串的小数位,使用 C3 在格式化时会进行四舍五入运算 ,因此1234.5678(C3) =>¥1,234.568

2. 标准格式说明符 图例

下表描述标准的数字格式说明符并显示由每个格式说明符产生的示例输出。

特定区域性的格式化字符串的结果可能与以下示例不同。操作系统设置、用户设置、环境变量和所用的 .NET 版本都会影响格式。 例如,从 .NET 5 开始,.NET 尝试跨平台统一区域性格式。 有关详细信息,请参阅 .NET 全球化和 ICU。

格式说明符格式类型说明示例
“B”或“b”二进制结果:二进制字符串。
类型支持:仅整型 (.NET 8+)。
精度说明符:结果字符串中的位数。
42 (B) -> 101010
255 (b16)-> 0000000011111111
“C”或“c”货币结果:货币值。
类型支持:所有数值类型。
精度说明符:十进制小数位数。
默认值精度说明符:2
123.456 (“C”, en-US) -> $123.46
123.456 (“C”, fr-FR) -> 123,46 €
123.456 (“C”, ja-JP) -> ¥123
-123.456 (“C3”, en-US) -> ($123.456)
-123.456 (“C3”, fr-FR) -> -123,456 €
-123.456 (“C3”, ja-JP) -> -¥123.456
“D”或“d”十进制结果:整型数字,负号可选。
类型支持:仅限整型类型。
精度说明符:数字位数下限。
默认值精度说明符:所需数字位数下限。
1234 (“D”) -> 1234
-1234 (“D6”) -> -001234
“E”或“e”指数(科学型)结果:指数表示法。
类型支持:所有数值类型。
精度说明符:十进制小数位数。
默认值精度说明符:6。
1052.0329112756 (“E”, en-US) -> 1.052033E+003
1052.0329112756 (“e”, fr-FR) -> 1,052033e+003
-1052.0329112756 (“e2”, en-US) -> -1.05e+003
-1052.0329112756 (“E2”, fr-FR) -> -1,05E+003
“F”或“f”定点结果:整数和十进制小数,负号可选。
类型支持:所有数值类型。
精度说明符:十进制小数位数。
默认值精度说明符:2。
1234.567 (“F”, en-US) -> 1234.57
1234.567 (“F”, de-DE) -> 1234,57
1234 (“F1”, en-US) -> 1234.0
1234 (“F1”, de-DE) -> 1234,0
-1234.56 (“F4”, en-US) -> -1234.5600
-1234.56 (“F4”, de-DE) -> -1234,5600
“G”或“g”常规结果:更紧凑的定点表示法或科学记数法。
类型支持:所有数值类型。
精度说明符:有效位数。
默认值精度说明符:具体取决于数值类型。
-123.456 (“G”, en-US) -> -123.456
-123.456 (“G”, sv-SE) -> -123,456
123.4546 (“G4”, en-US) -> 123.5
123.4546 (“G4”, sv-SE) -> 123,5
-1.234567890e-25 (“G”, en-US) -> -1.23456789E-25
-1.234567890e-25 (“G”, sv-SE) -> -1,23456789E-25
“N”或“n”数字结果:整数和十进制小数、
组分隔符和十进制小数分隔符,负号可选。
类型支持:所有数值类型。
精度说明符:所需的小数位数。
默认值精度说明符:2。
1234.567 (“N”, en-US) -> 1,234.57
1234.567 (“N”, ru-RU) -> 1 234,57
1234 (“N1”, en-US) -> 1,234.0
1234 (“N1”, ru-RU) -> 1 234,0
-1234.56 (“N3”, en-US) -> -1,234.560
-1234.56 (“N3”, ru-RU) -> -1 234,560
“P”或“p”百分比结果:数字乘以 100 并以百分比符号显示。
类型支持:所有数值类型。
精度说明符:所需的小数位数。
默认值精度说明符:2。
1 (“P”, en-US) -> 100.00 %
1 (“P”, fr-FR) -> 100,00 %
-0.39678 (“P1”, en-US) -> -39.7 %
-0.39678 (“P1”, fr-FR)-> -39,7 %
“R”或“r”往返过程结果:可以往返至相同数字的字符串。
类型支持:Single、Double 和 BigInteger。
精度说明符:已忽略。
123456789.12345678 (“R”) -> 123456789.12345678
-1234567890.12345678 (“R”) -> -1234567890.1234567
“X”或“x”十六进制结果:十六进制字符串。
类型支持:仅限整型类型。
精度说明符:结果字符串中的位数。
255 (“X”) -> FF
-1 (“x”) -> ff
255 (“x4”) -> 00ff
-1 (“X4”) -> 00FF
任何其他单个字符未知说明符结果:十六进制字符串。
类型支持:在运行时引发 FormatException。

二、标准数字格式说明符详解

1. B/b 二进制格式说明符

  • 二进制格式说明符 (B) 将数字转换为二进制数字字符串。 只有整型且仅在 .NET 8+ 上才支持此格式。

  • 结果字符串不受当前 NumberFormatInfo 对象的格式信息的影响。

        static void Main(string[] args){int value = 42;Console.WriteLine(value.ToString("B"));     //输出:101010Console.WriteLine(value.ToString("B0"));    //输出:101010Console.WriteLine(value.ToString("B1"));    //输出:101010Console.WriteLine(value.ToString("B3"));    //输出:101010Console.WriteLine(value.ToString("B5"));    //输出:101010Console.WriteLine(value.ToString("B8"));    //输出:00101010int value2 = 255;Console.WriteLine(value2.ToString("B"));    //输出:11111111Console.WriteLine(value2.ToString("B0"));   //输出:11111111Console.WriteLine(value2.ToString("B1"));   //输出:11111111Console.WriteLine(value2.ToString("B10"));  //输出:0011111111Console.WriteLine(value2.ToString("B16"));  //输出:0000000011111111Console.WriteLine(value2.ToString("B20"));  //输出:00000000000011111111}
  • 精度说明符指示结果字符串中所需的最少数字个数。 如果需要的话,则用零填充该数字的左侧,以产生精度说明符给定的数字个数

2. C/c 货币格式说明符

  • “C”(或货币)格式说明符将数字转换为表示货币金额的字符串。
  • 精度说明符指示结果字符串中的所需小数位数。
  • 如果省略精度说明符,则默认精度由 NumberFormatInfo.CurrencyDecimalDigits 属性定义,默认为 2。
        static void Main(string[] args){double amount = 1234.5678;Console.WriteLine(amount.ToString("C"));   // 输出: ¥1,234.57Console.WriteLine(amount.ToString("C0"));  // 输出: ¥1,235Console.WriteLine(amount.ToString("C1"));  // 输出: ¥1,234.6Console.WriteLine(amount.ToString("C2"));  // 输出: ¥1,234.57Console.WriteLine(amount.ToString("C3"));  // 输出: ¥1,234.568Console.WriteLine(amount.ToString("C4"));  // 输出: ¥1,234.5678Console.WriteLine(amount.ToString("C5"));  // 输出: ¥1,234.56780}
  • 如果要设置格式的值的小数位数多于指定或默认数量,将在结果字符串中补0。
    • 如 C5 指定小数位数为5 ,多于1234.5678 中的四位,那么格式化的时候会在结果中补0,结果为¥1,234.56780
  • 如果要设置格式的值的小数位数少于指定或默认数量,将在进行四舍五入后返回结果字符串。
    • 如 C2 指定小数位数为2 ,少于1234.5678 中的四位,那么格式化的时候会自动进行四舍五入,返回结果字符串¥1234.57
        static void Main(string[] args){double value = 12345.6789;Console.WriteLine(value.ToString("C3"));                                            //输出:¥12,345.679Console.WriteLine(value.ToString("C3", CultureInfo.CurrentCulture));                //输出:¥12,345.679Console.WriteLine(value.ToString("C3", new CultureInfo("en-US")));                  //输出:$12,345.679Console.WriteLine(value.ToString("C3", CultureInfo.CreateSpecificCulture("da-DK")));//输出:12.345,679 kr.}
  • 使用格式提供程序来实现特定区域性的格式设置约定。
  • 当不设置区域信息的时候,默认使用当前计算机的区域信息
  • 当需要指定特定的区域性的格式设置的时候,可以通过 CultureInfo 去指定
    • 如上面的案例中,使用了三种不同的方式去指定 区域
  • 结果字符串受当前 NumberFormatInfo 对象的格式信息的影响。 下表列出了 NumberFormatInfo 属性,这些属性控制返回字符串的格式。
    在这里插入图片描述

3. D/d 十进制格式说明符

  • “D”(或十进制)格式说明符将数字转换为十进制数字 (0-9) 的字符串,如果数字为负,则前面加负号。
  • 只有整型才支持此格式
  • 精度说明符指示结果字符串中所需的最少数字个数。
        static void Main(string[] args){int number = 1234;Console.WriteLine(number.ToString("D"));   // 输出: 1234Console.WriteLine(number.ToString("D1"));  // 输出: 1234Console.WriteLine(number.ToString("D3"));  // 输出: 1234Console.WriteLine(number.ToString("D4"));  // 输出: 1234Console.WriteLine(number.ToString("D5"));  // 输出: 01234Console.WriteLine(number.ToString("D7"));  // 输出: 0001234Console.WriteLine(number.ToString("D8"));  // 输出: 00001234}
  • 如果未指定精度说明符,则默认值为表示不带前导零的整数所需的最小值

    • 1234(D) -> 1234
  • 如果精度说明符给定的数字个数 大于 数字本身的数字位数,则用零填充该数字的左侧满足精度说明符给定的数字个数。

    • 1234(D8) -> 00001234
  • 如果精度说明符给定的数字个数 小于 数字本身的数字位数,则保留数字本身的数值。

    • 1234(D2) -> 12341234(D3) -> 1234
  • 结果字符串受当前 NumberFormatInfo 对象的格式信息的影响。 如下表所示,一个属性会影响结果字符串的格式。
    在这里插入图片描述

4. E/e 指数格式说明符

  • 指数(“E”)格式说明符将数字转换为“-d.ddd…E+ddd”或“-d.ddd…e+ddd”形式的字符串,其中每个“d”表示一个数字 (0-9)。 如果该数字为负,则该字符串以减号开头。 小数点前总是恰好有一个数字。
  • 精度说明符指示小数点后所需的位数。
        static void Main(string[] args){double amount = 1234.5678;Console.WriteLine(amount.ToString("E"));   // 输出: 1.234568E+003Console.WriteLine(amount.ToString("E0"));  // 输出: 1E+003Console.WriteLine(amount.ToString("E1"));  // 输出: 1.2E+003Console.WriteLine(amount.ToString("E2"));  // 输出: 1.23E+003Console.WriteLine(amount.ToString("E3"));  // 输出: 1.235E+003Console.WriteLine(amount.ToString("E4"));  // 输出: 1.2346E+003Console.WriteLine(amount.ToString("E5"));  // 输出: 1.23457E+003}
  • 如果省略精度说明符,则使用默认值,即小数点后六位数字。
    • 1234.5678(E) -> 1.234568E+003
        static void Main(string[] args){double value = 12345.6789;Console.WriteLine(value.ToString("E", CultureInfo.InvariantCulture));               // 输出: 1.234568E+004Console.WriteLine(value.ToString("E10", CultureInfo.InvariantCulture));             // 输出: 1.2345678900E+004Console.WriteLine(value.ToString("e4", CultureInfo.InvariantCulture));              // 输出: 1.2346e+004Console.WriteLine(value.ToString("E",CultureInfo.CreateSpecificCulture("fr-FR")));  // 输出: 1,234568E+004 }
  • 格式说明符的大小写指示为指数加前缀“E”还是“e”。
    • 12345.6789(E) -> 1.234568E+00412345.6789(e4) -> 1.2346e+004
  • 指数总是由正号或负号以及最少三位数字组成。 如果需要,用零填充指数以满足最少三位数字的要求。
  • 结果字符串受当前 NumberFormatInfo 对象的格式信息的影响。 下表列出了 NumberFormatInfo 属性,这些属性控制返回字符串的格式。
    在这里插入图片描述

5. F/f 定点格式说明符

  • 定点(“F”)格式说明符将数字转换为“-ddd.ddd…”形式的字符串,其中每个“d”表示一个数字 (0-9)。 如果该数字为负,则该字符串以减号开头。
  • 精度说明符指示所需的小数位数。
        static void Main(string[] args){double amount = 1234.5678;Console.WriteLine(amount.ToString("数值F"));    // 输出: 数值FConsole.WriteLine(amount.ToString("F。"));      // 输出: F。Console.WriteLine(amount.ToString("F"));        // 输出: 1234.57Console.WriteLine(amount.ToString("F0"));       // 输出: 1235Console.WriteLine(amount.ToString("F1"));       // 输出: 1234.6Console.WriteLine(amount.ToString("F2"));       // 输出: 1234.57Console.WriteLine(amount.ToString("F3"));       // 输出: 1234.568Console.WriteLine(amount.ToString("F4"));       // 输出: 1234.5678Console.WriteLine(amount.ToString("F5"));       // 输出: 1234.56780double amount2 = 12.30;Console.WriteLine(amount2.ToString("F"));        // 输出: 12.30Console.WriteLine(amount2.ToString("F3"));       // 输出: 12.300Console.WriteLine(amount2.ToString("F4"));       // 输出: 12.3000         }
  • 如果省略精度说明符,则当前NumberFormatInfo.NumberDecimalDigits 属性提供数值精度,默认值 2。

    • 1234.5678(F) -> 1234.57
  • 如果要设置格式的值的小数位数多于指定或默认数量,将在结果字符串中补0。

    • 如 F5 指定小数位数为5 ,多于1234.5678 中的四位,那么格式化的时候会在结果中补0,结果为1234.56780
  • 如果要设置格式的值的小数位数少于指定或默认数量,将在进行四舍五入后返回结果字符串。

    • 如 F3 指定小数位数为3 ,少于1234.5678 中的四位,那么格式化的时候会自动进行四舍五入,返回结果字符串1234.568
  • 结果字符串受当前 NumberFormatInfo 对象的格式信息的影响。 下表列出了 NumberFormatInfo 对象的属性,这些属性控制结果字符串的格式。
    在这里插入图片描述

6. G/g 常规格式说明符

  • 根据数字类型以及是否存在精度说明符,常规(“G”)格式说明符将数字转换为更紧凑的定点表示法或科学记数法。
  • 精度说明符定义可以出现在结果字符串中的最大有效位数
        static void Main(string[] args){double amount = 1234.5678;Console.WriteLine(amount.ToString("数值G"));    // 输出: 数值GConsole.WriteLine(amount.ToString("G。"));      // 输出: G。Console.WriteLine(amount.ToString("G"));        // 输出: 1234.5678Console.WriteLine(amount.ToString("G0"));       // 输出: 1234.5678Console.WriteLine(amount.ToString("G1"));       // 输出: 1E+03Console.WriteLine(amount.ToString("G2"));       // 输出: 1.2E+03Console.WriteLine(amount.ToString("G3"));       // 输出: 1.23E+03Console.WriteLine(amount.ToString("G4"));       // 输出: 1235Console.WriteLine(amount.ToString("G5"));       // 输出: 1234.6double amount2 = 12.30;Console.WriteLine(amount2.ToString("G"));        // 输出: 12.3Console.WriteLine(amount2.ToString("G1"));       // 输出: 1E+01Console.WriteLine(amount2.ToString("G2"));       // 输出: 12Console.WriteLine(amount2.ToString("G3"));       // 输出: 12.3Console.WriteLine(amount2.ToString("G4"));       // 输出: 12.3    }
  • 如果精度说明符被省略或为零,则数字的类型决定默认精度,如下表所示。
    在这里插入图片描述
  • 如果用科学记数法表示数字时指数大于 -5 而且小于精度说明符,则使用定点表示法;否则使用科学记数法。 结果包含小数点(如果需要),并且忽略小数点后面的尾部零。 如果精度说明符存在,并且结果的有效位数超过指定精度,则通过舍入移除多余的尾部数字。
    在这里插入图片描述
  • 结果字符串受当前 NumberFormatInfo 对象的格式信息的影响。 下表列出了 NumberFormatInfo 属性,这些属性控制结果字符串的格式。
    在这里插入图片描述

7. N/n 数字格式说明符

  • 数字(“N”)格式说明符将数字转换为"-d,ddd,ddd.ddd…“形式的字符串,其中”-"表示负数符号(如果需要),“d"表示数字 (0-9),”,“表示组分隔符,”."表示小数点符号。
  • 精度说明符指示小数点后所需的位数。
        static void Main(string[] args){double amount = 1234.5678;Console.WriteLine(amount.ToString("数值N"));    // 输出: 数值NConsole.WriteLine(amount.ToString("N。"));      // 输出: N。Console.WriteLine(amount.ToString("N"));        // 输出: 1,234.57Console.WriteLine(amount.ToString("N0"));       // 输出: 1,235Console.WriteLine(amount.ToString("N1"));       // 输出: 1,234.6Console.WriteLine(amount.ToString("N2"));       // 输出: 1,234.57Console.WriteLine(amount.ToString("N3"));       // 输出: 1,234.568Console.WriteLine(amount.ToString("N4"));       // 输出: 1,234.5678Console.WriteLine(amount.ToString("N5"));       // 输出: 1,234.56780double amount2 = 12.30;Console.WriteLine(amount2.ToString("N"));        // 输出: 12.30Console.WriteLine(amount2.ToString("N1"));       // 输出: 12.3Console.WriteLine(amount2.ToString("N2"));       // 输出: 12.30Console.WriteLine(amount2.ToString("N3"));       // 输出: 12.300Console.WriteLine(amount2.ToString("N4"));       // 输出: 12.3000}
  • 如果省略精度限定符,则小数位数由当前的 NumberFormatInfo.NumberDecimalDigits 属性来定义,默认值2。
    • 1234.5678(N) -> 1234.57
  • N 符号 是进阶版 F 符号,N 符号基于F符号的基础上多了一个组分隔符","
    • 1234.5678(N5) ->1,234.56780
    • 1234.5678(F5) ->1234.56780
  • 结果字符串受当前 NumberFormatInfo 对象的格式信息的影响。 下表列出了 NumberFormatInfo 属性,这些属性控制结果字符串的格式。
    在这里插入图片描述

8. P/p 百分比格式说明符

  • 百分比(“P”)格式说明符将数字乘以 100 并将其转换为表示百分比的字符串。
  • 精度说明符指示所需的小数位数。
        static void Main(string[] args){double amount = 1234.5678;Console.WriteLine(amount.ToString("数值P"));    // 输出: 数值PConsole.WriteLine(amount.ToString("P。"));      // 输出: P。Console.WriteLine(amount.ToString("P"));        // 输出: 123,456.78%Console.WriteLine(amount.ToString("P0"));       // 输出: 123,457%Console.WriteLine(amount.ToString("P1"));       // 输出: 123,456.8%Console.WriteLine(amount.ToString("P2"));       // 输出: 123,456.78%Console.WriteLine(amount.ToString("P3"));       // 输出: 123,456.780%Console.WriteLine(amount.ToString("P4"));       // 输出: 123,456.7800%Console.WriteLine(amount.ToString("P5"));       // 输出: 123,456.78000%double amount2 = 12.30;Console.WriteLine(amount2.ToString("P"));        // 输出: 1,230.00%Console.WriteLine(amount2.ToString("P1"));       // 输出: 1,230.0%Console.WriteLine(amount2.ToString("P2"));       // 输出: 1,230.00%Console.WriteLine(amount2.ToString("P3"));       // 输出: 1,230.000%Console.WriteLine(amount2.ToString("P4"));       // 输出: 1,230.0000%}
  • 如果省略精度说明符,则使用当前 PercentDecimalDigits 属性提供的默认数值精度,默认值 2。
    • 1234.5678(P) -> 123,456.78%
        static void Main(string[] args){double number = .2468013; // 相当于0.2468013Console.WriteLine(number.ToString("P4", CultureInfo.InvariantCulture));               // Displays 24.6801 %Console.WriteLine(number.ToString("P4", CultureInfo.CreateSpecificCulture("zh-CN"))); // Displays 24.6801%Console.WriteLine(number.ToString("P4", CultureInfo.CreateSpecificCulture("en-US"))); // Displays 24.6801%}
  • 使用CultureInfo.InvariantCulture 和 中英区域的区别
    • 0.2468013(P4)-> 24.6801 % (InvariantCulture) 多个空格
    • 0.2468013(P4)-> 24.6801% (zh-CN)
    • 0.2468013(P4)-> 24.6801% (en-US)

9. R/r 往返格式说明符

  • 往返 (“R”) 格式说明符试图确保将转换为字符串的数值分析回相同的数值。
  • 只有 Half、Single、Double 和 BigInteger 类型支持此格式。
  • 在低于 3.0 的 .NET Framework 和 .NET Core 版本中,
    • 在某些情况下,“R”格式说明符无法成功往返传送 Double 值。
      • 对于 Double 值和 Single 值,“R”格式说明符提供相对较差的性能。
      • 建议改用 “G17” 格式说明符以成功往返 Double 值,
      • 并改用 “G9” 格式说明符以成功往返 Single 值。
  • 如果使用此说明符设置 BigInteger 值的格式,其字符串表示形式将包含 BigInteger 值中的所有有效位。

该符号使用较少,有兴趣的可查阅:往返格式说明符 ®

10. X/x 的使用

  • 十六进制(“X”)格式说明符将数字转换为十六进制数的字符串。
  • 格式说明符的大小写指示对大于 9 的十六进制数使用大写字符还是小写字符。
    • 例如,使用“X”产生“ABCDEF”,使用“x”产生“abcdef”。
  • 只有整型才支持此格式
  • 精度说明符指示结果字符串中所需的最少数字个数。
        static void Main(string[] arXs){int amount = 15;int amount2 = 1115;Console.WriteLine(amount.ToString("数值X"));        // 输出: 数值XConsole.WriteLine(amount.ToString("X。"));          // 输出: X。Console.WriteLine(amount.ToString("X"));            // 输出: FConsole.WriteLine(amount.ToString("X1"));           // 输出: FConsole.WriteLine(amount.ToString("X2"));           // 输出: 0FConsole.WriteLine(amount.ToString("X3"));           // 输出: 00FConsole.WriteLine(amount.ToString("X4"));           // 输出: 000FConsole.WriteLine(amount2.ToString("X"));           // 输出: 45BConsole.WriteLine(amount2.ToString("X2"));          // 输出: 45BConsole.WriteLine(amount2.ToString("X3"));          // 输出: 45BConsole.WriteLine(amount2.ToString("X4"));          // 输出: 045B}
  • 如果精度说明符给定的数字个数 大于 数字本身的数值,则用零填充该数字的左侧满足精度说明符给定的数字个数。
    • 15(X4) -> 000F
  • 如果精度说明符给定的数字个数 小于 数字本身的数值,则保留数字本身的16进制数值。
    • 1115(X2) -> 45B1115(X3) -> 45B
  • 结果字符串不受当前 NumberFormatInfo 对象的格式信息的影响。

三、相关信息

本章节主要介绍 使用 标准数字格式字符串 时会涉及到的相关知识

1. 区域设置

1)控制面板设置

在这里插入图片描述
控制面板中 “区域和语言选项” 项中的设置会影响由格式化操作产生的结果字符串。

2)使用 CultureInfo

通过 CultureInfo 去指定特定的区域性的格式设置,如下所示:

        static void Main(string[] args){double value = 12345.6789;Console.WriteLine(value.ToString("C3"));                                            //输出:¥12,345.679Console.WriteLine(value.ToString("C3", CultureInfo.CurrentCulture));                //输出:¥12,345.679Console.WriteLine(value.ToString("C3", new CultureInfo("en-US")));                  //输出:$12,345.679Console.WriteLine(value.ToString("C3", CultureInfo.CreateSpecificCulture("da-DK")));//输出:12.345,679 kr.}

注:Windows 系统上可用的区域性的预定义区域性标识符在 Windows 支持的语言/区域名称列表中的“语言标记”列中列出。 列名遵循 BCP 47 定义的标准。

2. 整型和浮点型数值类型

对标准数字格式说明符的一些说明涉及到整型或浮点型数值类型。

  • 整型数值类型包括 Byte、SByte、Int16、Int32、Int64、UInt16、UInt32、UInt64 和 BigInteger。
  • 浮点型数值类型有 Decimal、Half、Single 和 Double。

3. 浮点型无穷大和 NaN

无论格式字符串原来是什么值,只要 Half、Single 或 Double 浮点类型的值为正无穷大、负无穷大或非数值 (NaN),格式字符串就分别是当前适用的 NumberFormatInfo 对象指定的 PositiveInfinitySymbol、NegativeInfinitySymbol 或 NaNSymbol 属性的值。

2. NumberFormatInfo

格式设置受当前 NumberFormatInfo 对象的属性影响,它由当前区域性隐式提供或由调用格式设置的方法的 IFormatProvider 参数显式提供。 为该参数指定 NumberFormatInfo 或 CultureInfo 对象。

1)NumberFormatInfo 介绍

提供用于对数字值进行格式设置和分析的区域性特定信息。

public sealed class NumberFormatInfo : ICloneable, IFormatProvider

详见:NumberFormatInfo 类,NumberFormatInfo 中属性基本覆盖了我们想要对数字格式进行设置的绝大部分操作,可以辅助我们得到满意的格式设置的数字格式的字符串。

2) 常见属性的使用

  • CurrencyDecimalDigits
    • 获取或设置在货币值中使用的小数位数。
        static void Main(string[] args){// 获取与en-US区域性关联的NumberFormatInfo。NumberFormatInfo nfi = new CultureInfo("en-US", false).NumberFormat;// 显示默认小数位数(2)的负值。Int64 myInt = -1234;Console.WriteLine(myInt.ToString("C", nfi)); //-$1,234.00// 设置在货币值中使用的小数位数。// 用四位小数显示相同的值。nfi.CurrencyDecimalDigits = 4;Console.WriteLine(myInt.ToString("C", nfi)); // -$1,234.0000}
  • CurrencyDecimalSeparator
    • 获取或设置要在货币值中用作小数分隔符的字符串。
        static void Main(string[] args){// 获取与en-US区域性关联的NumberFormatInfo。NumberFormatInfo nfi = new CultureInfo("en-US", false).NumberFormat;// 显示带有默认分隔符(“.”)的值。Int64 myInt = 123456789;Console.WriteLine(myInt.ToString("C", nfi));    //$123,456,789.00// 以空格显示与分隔符相同的值。nfi.CurrencyDecimalSeparator = " ";Console.WriteLine(myInt.ToString("C", nfi));    //$123,456,789 00}
  • CurrencyGroupSeparator
    • 获取或设置在货币值中隔开小数点左边的位数组的字符串。
    • 在货币值中隔开小数点左边的位数组的字符串。 InvariantInfo 默认为“,”。
        static void Main(string[] args){// 获取与en-US区域性关联的NumberFormatInfo。NumberFormatInfo nfi = new CultureInfo("en-US", false).NumberFormat;// 显示带有默认分隔符(“,”)的值Int64 myInt = 123456789;Console.WriteLine(myInt.ToString("C", nfi));    //$123,456,789.00// 以空格显示与分隔符相同的值。nfi.CurrencyGroupSeparator = " ";Console.WriteLine(myInt.ToString("C", nfi));    //$123 456 789.00}
  • CurrencyPositivePattern
    获取或设置正货币值的格式模式。
        static void Main(string[] args){// 获取与en-US区域性关联的NumberFormatInfo。NumberFormatInfo nfi = new CultureInfo("en-US", false).NumberFormat;Int64 myInt = 123456789;Console.WriteLine(myInt.ToString("C", nfi));    //$123,456,789.00nfi.CurrencyPositivePattern = 1;Console.WriteLine(myInt.ToString("C", nfi));    //123,456,789.00$}

属性 CurrencyPositivePattern 与“C”标准格式字符串一起使用,以定义正货币值的模式。
在这里插入图片描述

  • CurrencySymbol
    获取或设置用作货币符号的字符串。
        static void Main(string[] args){// 获取与en-US区域性关联的NumberFormatInfo。NumberFormatInfo nfi = new CultureInfo("en-US", false).NumberFormat;Int64 myInt = 123456789;Console.WriteLine(myInt.ToString("C", nfi));    // $123,456,789.00Console.WriteLine(nfi.CurrencySymbol);          // $nfi.CurrencySymbol = "&";Console.WriteLine(myInt.ToString("C", nfi));    // &123,456,789.00}

扩展:如果在开发WPF项目的时候,使用字体图标,通过CurrencySymbol 可以设置货币符号,那么这个货币符号将有很大的扩展性

  • InvariantInfo
    获取不依赖于区域性的(固定)只读的 NumberFormatInfo 对象。
using System;
using System.Globalization;
using System.Text;class SamplesNumberFormatInfo  {public static void Main()  {// Gets the InvariantInfo.NumberFormatInfo myInv = NumberFormatInfo.InvariantInfo;// Gets a UnicodeEncoding to display the Unicode value of symbols.UnicodeEncoding myUE = new UnicodeEncoding( true, false );byte[] myCodes;// Displays the default values for each of the properties.Console.WriteLine( "InvariantInfo:\nNote: Symbols might not display correctly on the console,\ntherefore, Unicode values are included." );Console.WriteLine( "\tCurrencyDecimalDigits\t\t{0}", myInv.CurrencyDecimalDigits );Console.WriteLine( "\tCurrencyDecimalSeparator\t{0}", myInv.CurrencyDecimalSeparator );Console.WriteLine( "\tCurrencyGroupSeparator\t\t{0}", myInv.CurrencyGroupSeparator );Console.WriteLine( "\tCurrencyGroupSizes\t\t{0}", myInv.CurrencyGroupSizes[0] );Console.WriteLine( "\tCurrencyNegativePattern\t\t{0}", myInv.CurrencyNegativePattern );Console.WriteLine( "\tCurrencyPositivePattern\t\t{0}", myInv.CurrencyPositivePattern );myCodes = myUE.GetBytes( myInv.CurrencySymbol );Console.WriteLine( "\tCurrencySymbol\t\t\t{0}\t(U+{1:x2}{2:x2})", myInv.CurrencySymbol, myCodes[0], myCodes[1] );Console.WriteLine( "\tNaNSymbol\t\t\t{0}", myInv.NaNSymbol );Console.WriteLine( "\tNegativeInfinitySymbol\t\t{0}", myInv.NegativeInfinitySymbol );Console.WriteLine( "\tNegativeSign\t\t\t{0}", myInv.NegativeSign );Console.WriteLine( "\tNumberDecimalDigits\t\t{0}", myInv.NumberDecimalDigits );Console.WriteLine( "\tNumberDecimalSeparator\t\t{0}", myInv.NumberDecimalSeparator );Console.WriteLine( "\tNumberGroupSeparator\t\t{0}", myInv.NumberGroupSeparator );Console.WriteLine( "\tNumberGroupSizes\t\t{0}", myInv.NumberGroupSizes[0] );Console.WriteLine( "\tNumberNegativePattern\t\t{0}", myInv.NumberNegativePattern );Console.WriteLine( "\tPercentDecimalDigits\t\t{0}", myInv.PercentDecimalDigits );Console.WriteLine( "\tPercentDecimalSeparator\t\t{0}", myInv.PercentDecimalSeparator );Console.WriteLine( "\tPercentGroupSeparator\t\t{0}", myInv.PercentGroupSeparator );Console.WriteLine( "\tPercentGroupSizes\t\t{0}", myInv.PercentGroupSizes[0] );Console.WriteLine( "\tPercentNegativePattern\t\t{0}", myInv.PercentNegativePattern );Console.WriteLine( "\tPercentPositivePattern\t\t{0}", myInv.PercentPositivePattern );myCodes = myUE.GetBytes( myInv.PercentSymbol );Console.WriteLine( "\tPercentSymbol\t\t\t{0}\t(U+{1:x2}{2:x2})", myInv.PercentSymbol, myCodes[0], myCodes[1] );myCodes = myUE.GetBytes( myInv.PerMilleSymbol );Console.WriteLine( "\tPerMilleSymbol\t\t\t{0}\t(U+{1:x2}{2:x2})", myInv.PerMilleSymbol, myCodes[0], myCodes[1] );Console.WriteLine( "\tPositiveInfinitySymbol\t\t{0}", myInv.PositiveInfinitySymbol );Console.WriteLine( "\tPositiveSign\t\t\t{0}", myInv.PositiveSign );}
}/*This code produces the following output.InvariantInfo:
Note: Symbols might not display correctly on the console,
therefore, Unicode values are included.CurrencyDecimalDigits           2CurrencyDecimalSeparator        .CurrencyGroupSeparator          ,CurrencyGroupSizes              3CurrencyNegativePattern         0CurrencyPositivePattern         0CurrencySymbol                         (U+00a4)NaNSymbol                       NaNNegativeInfinitySymbol          -InfinityNegativeSign                    -NumberDecimalDigits             2NumberDecimalSeparator          .NumberGroupSeparator            ,NumberGroupSizes                3NumberNegativePattern           1PercentDecimalDigits            2PercentDecimalSeparator         .PercentGroupSeparator           ,PercentGroupSizes               3PercentNegativePattern          0PercentPositivePattern          0PercentSymbol                   %       (U+0025)PerMilleSymbol                  %       (U+2030)PositiveInfinitySymbol          InfinityPositiveSign                    +*/

结语

回到目录页:C# 知识汇总
希望以上内容可以帮助到大家,如文中有不对之处,还请批评指正。


参考资料
标准数字格式字符串
概述:如何在 .NET 中设置数字、日期、枚举和其他类型的格式

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/501123.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络分析工具-tcpdump

文章目录 前言一、tcpdump基础官网链接命令选项详解常规过滤规则tcpdump输出 一、tcpdump实践HTTP协议ICMP状态抓包 前言 当遇到网络疑难问题的时候,抓包是最基本的技能,通过抓包才能看到网络底层的问题 一、tcpdump基础 tcpdump是一个常用的网络分析工…

【微软,模型规模】模型参数规模泄露:理解大型语言模型的参数量级

模型参数规模泄露:理解大型语言模型的参数量级 关键词: #大型语言模型 Large Language Model #参数规模 Parameter Scale #GPT-4o #GPT-4o-mini #Claude 3.5 Sonnet 具体实例与推演 近日,微软在一篇医学相关论文中意外泄露了OpenAI及Claud…

springboot集成qq邮箱服务

springboot集成qq邮箱服务 1.获取QQ邮箱授权码 1.1 登录QQ邮箱 1.2 开启SMTP服务 找到下图中的SMTP服务区域,如果当前账号未开启的话自己手动开启。 1.3 获取授权码 进入上图中的【管理服务】后:在【安全设置中生成授权码】,也可以直接点击【继续生成…

Windows系统提示ffmpeg.dll丢失怎么解决?

一、了解ffmpeg.dll文件 ffmpeg.dll是FFmpeg项目的一个动态链接库文件,FFmpeg是一个开源的多媒体处理框架,能够解码、编码、转码、混流、过滤和播放几乎所有已知格式的音频和视频文件。当Windows系统提示ffmpeg.dll丢失时,通常意味着某个需要…

直观解读 JuiceFS 的数据和元数据设计(一)

大家读完觉得有意义和帮助记得关注和点赞!!! 1 JuiceFS 高层架构与组件2 搭建极简 JuiceFS 集群 2.1 搭建元数据集群2.2 搭建对象存储(MinIO) 2.2.1 启动 MinIO server2.2.2 创建 bucket2.3 下载 juicefs 客户端2.4 创…

分布式微服务项目___某污水处理项目

一.分布式微服务项目___污水处理项目 项目地址:https://gitee.com/yanyigege/collaborative-water-springboot.git ​ 1.项目背景 总公司在全国各地有处理污水的项目部,各项目部处理自己的污水,总部需要监控各地分项目部每天处理污水的原料用量,掌握各分部的污水处理情况 ​…

鸿蒙HarmonyOS开发:拨打电话、短信服务、网络搜索、蜂窝数据、SIM卡管理、observer订阅管理

文章目录 一、call模块(拨打电话)1、使用makeCall拨打电话2、获取当前通话状态3、判断是否存在通话4、检查当前设备是否具备语音通话能力 二、sms模块(短信服务)1、创建短信2、发送短信 三、radio模块(网络搜索&#x…

TVS二极管选型【EMC】

TVS器件并联在电路中,当电路正常工作时,他处于截止状态(高阻态),不影响线路正常工作,当线路处于异常过压并达到其击穿电压时,他迅速由高阻态变为低阻态,给瞬间电流提供一个低阻抗导通…

sqlalchemy-access库操作MS Access

因目前项目中数据处理的量稍大,为了方便和业务进行交互,对数据的加工和处理放到微软桌面数据库MS Access中。然后有些地方通过 Python 来操作 MS Access 数据库,用到 sqlalchemy-access库。本文对操作的要点做简单的描述。 之前写过一篇 Pyt…

UnityRenderStreaming使用记录(三)

测试UnityRenderStreaming在Ubuntu24.04.1LTS上的表现 先放上运行图操作系统 Ubuntu24.04.1LTSUnity测试工程环境相关修改遇到的问题 先放上运行图 操作系统 Ubuntu24.04.1LTS 系统下载地址 https://cn.ubuntu.com/download/desktop安装UnityHub https://blog.csdn.net/AWNUXC…

==和===的区别,被坑的一天

在 JavaScript 中, 和 都用于比较两个值,但它们有一个重要的区别: 1. (宽松相等运算符) 进行比较时,会 自动类型转换(也叫做强制类型转换),即如果比较的两个值的类型不同,JavaScr…

Git的使用流程(详细教程)

目录 01.Git是什么? 1.1 Git简介 1.2 SVN与Git的最主要的区别 1.3 GIt主要特点 02.Git是干什么的? 2.1.Git概念汇总 2.2 工作区/暂存区/仓库 2.3 Git使用流程 03.Git的安装配置 3.1 Git的配置文件 3.2 配置-初始化用户 3.3 Git可视化…

使用Docker部署最新版JupyterHub

拉取镜像 docker pull jupyterhub/jupyterhub:latest启动镜像 docker run -d -p 8000:8000 --name jupyterhub jupyterhub/jupyterhub:latest jupyterhub进入容器 docker exec -it jupyterhub bash生成jupyterhub的配置文件 jupyterhub --generate-config# 有需要可以安装中…

liunx下载gitlab

1.地址: https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/ 安装 postfix 并启动 yum install postfix systemctl start postfix systemctl enable postfix ssh服务启动 systemctl enable sshd systemctl start sshd开放 ssh 以及 http 服务&#xff0c…

【AI大模型】深入GPT-2模型细节:揭秘其卓越性能的秘密

目录 🍔 GPT2的架构 🍔 GPT2模型的细节 2.1 模型过程 2.2 GPT2工作细节探究 🍔 小结 学习目标 掌握GPT2的架构掌握GPT2的训练任务和模型细节 🍔 GPT2的架构 从模型架构上看, GPT2并没有特别新颖的架构, 它和只带有解码器模块…

oceanbase集群访问异常问题处理

1.报错现象 2.问题排查 检查obproxy状态发现为不可用状态 重启obproxy 依次重启Obproxy集群 观察任务状态 重启完成 Obproxy状态正常 3.验证登录 登录成功

Echarts+vue电商平台数据可视化——webSocket改造项目

websocket的基本使用,用于测试前端能否正常获取到后台数据 后台代码编写: const path require("path"); const fileUtils require("../utils/file_utils"); const WebSocket require("ws"); // 创建WebSocket服务端的…

【数据结构】双向循环链表的使用

双向循环链表的使用 1.双向循环链表节点设计2.初始化双向循环链表-->定义结构体变量 创建头节点(1)示例代码:(2)图示 3.双向循环链表节点头插(1)示例代码:(2&#xff…

【深度学习】卷积网络代码实战ResNet

ResNet (Residual Network) 是由微软研究院的何凯明等人在2015年提出的一种深度卷积神经网络结构。ResNet的设计目标是解决深层网络训练中的梯度消失和梯度爆炸问题,进一步提高网络的表现。下面是一个ResNet模型实现,使用PyTorch框架来展示如何实现基本的…

【51项目】51单片机自制小霸王游戏机

视频演示效果: 纳新作品——小霸王游戏机 目录: 目录 视频演示效果: 目录: 前言: 一、连接方式: 1.1 控制引脚 1.2. 显示模块 1.3. 定时器 1.4. 游戏逻辑与硬件结合 1.5. 中断处理 二、源码分析&#xff1a…