DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字。该类设计有各种功能,使其能够分析和格式化任意语言环境中的数,包括对西方语言、阿拉伯语和印度语数字的支持。它还支持不同类型的数,包括整数 (123)、定点数 (123.4)、科学记数法表示的数 (1.23E4)、百分数 (12%) 和金额 ($123)。所有这些内容都可以本地化。 DecimalFormat 包含一个模式 和一组符号 。
符号 | 位置 | 本地化 | 含义 |
| 数字 | 是 | 阿拉伯数字 |
| 数字字 | 是 | 阿拉伯数字,如果不存在则显示为空 |
| 数字 | 是 | 小数分隔符或货币小数分隔符 |
| 数字 | 是 | 减号 |
| 数字 | 是 | 分组分隔符 |
| 数字 | 是 | 分隔科学计数法中的尾数和指数。在前缀或后缀中无需加引号。 |
| 子模式边界 | 是 | 分隔正数和负数子模式 |
| 前缀或后缀 | 是 | 乘以 100 并显示为百分数 |
| 前缀或后缀 | 是 | 乘以 1000 并显示为千分数 |
| 前缀或后缀 | 否 | 货币记号,由货币符号替换。如果两个同时出现,则用国际货币符号替换。如果出现在某个模式中,则使用货币小数分隔符,而不使用小数分隔符。 |
| 前缀或后缀 | 否 | 用于在前缀或或后缀中为特殊字符加引号,例如 |
测试代码:
package math;
import java.text.DecimalFormat;
public class Arith {
public static void main(String[] args) {
DecimalFormat df = new DecimalFormat();
double data = 1234.56789;
System.out.println("格式化之前的数字: " + data);
// 定义要显示的数字的格式,模式中的"#"表示如果位数不足则以 0填充
String style = "0.00000000";
df.applyPattern(style); // 将格式应用于格式化器
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 模式中的"#"表示如果该位存在字符,则显示字符,如果不存在,则不显示。
style = "######.##########";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 在格式后添加单位字符
style = "00000.000 kg";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 模式中的"-"表示输出为负数,要放在最前面
style = "-000.000";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 模式中的","在数字中添加逗号,方便读数字
style = "-0,000.0#";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 模式中的"E"表示输出为指数,"E"之前的字符串是底数的格式,"E"之后的是字符串是指数的格式
style = "0.000E000";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 模式中的"%"表示乘以100并显示为百分数,要放在最后。
style = "0.00 %";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 模式中的"\u2030"表示乘以1000并显示为千分数,要放在最后。
style = "0.00 \u2030";
DecimalFormat df1 = new DecimalFormat(style); //在构造函数中设置数字格式
System.out.println("采用style: " + style + " 格式化之后: " + df1.format(data));
// 以逗号分隔
// 如果使用具有多个分组字符的模式,则最后一个分隔符和整数结尾之间的间隔才是使用的分组大小。
// 所以 "#,##,###,####" == "######,####" == "##,####,####"。
style = "000,0,00.##########";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 嵌入文本中
style = "这件衣服的价格是 ##.## 元";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 货币符号
style = "##.##\u00A4\u00A4";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
// 特殊符号
style = "'#'##.##";
df.applyPattern(style);
System.out.println("采用style: " + style + " 格式化之后: " + df.format(data));
}
}
结果:
格式化之前的数字: 1234.56789
采用style: 0.00000000 格式化之后: 1234.56789000
采用style: ######.########## 格式化之后: 1234.56789
采用style: 00000.000 kg 格式化之后: 01234.568 kg
采用style: -000.000 格式化之后: -1234.568
采用style: -0,000.0# 格式化之后: -1,234.57
采用style: 0.000E000 格式化之后: 1.235E003
采用style: 0.00 % 格式化之后: 123456.79 %
采用style: 0.00 ‰ 格式化之后: 1234567.89 ‰
采用style: 000,0,00.########## 格式化之后: 00,12,34.56789
采用style: 这件衣服的价格是 ##.## 元 格式化之后: 这件衣服的价格是 1234.57 元
采用style: ##.##¤¤ 格式化之后: 1234.57CNY
采用style: '#'##.## 格式化之后: #1234.57