|
|||||||||
摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 |
java.text
类 DecimalFormat
java.lang.Object java.text.Format java.text.NumberFormat java.text.DecimalFormat
- 所有已实现的接口:
- Serializable, Cloneable
-
public class DecimalFormat
- extends NumberFormat
DecimalFormat
是 NumberFormat
的一个具体子类,用于格式化十进制数字。该类设计有各种功能,使其能够分析和格式化任意语言环境中的数,包括对西方语言、阿拉伯语和印度语数字的支持。它还支持不同类型的数,包括整数 (123)、定点数 (123.4)、科学记数法表示的数 (1.23E4)、百分数 (12%) 和金额 ($123)。所有这些内容都可以本地化。
要获取具体语言环境的 NumberFormat
(包括默认语言环境),可调用 NumberFormat
的某个工厂方法,如 getInstance()
。通常不直接调用 DecimalFormat
的构造方法,因为 NumberFormat
的工厂方法可能返回不同于 DecimalFormat
的子类。如果需要自定义格式对象,可执行:
NumberFormat f = NumberFormat.getInstance(loc); if (f instanceof DecimalFormat) { ((DecimalFormat) f).setDecimalSeparatorAlwaysShown(true); }
DecimalFormat
包含一个模式 和一组符号。可直接使用 applyPattern()
或间接使用 API 方法来设置模式。符号存储在 DecimalFormatSymbols
对象中。使用 NumberFormat
工厂方法时,可从已本地化的 ResourceBundle
中读取模式和符号。
模式
DecimalFormat
模式具有下列语法:
模式: 正数模式 正数模式;负数模式 正数模式: 前缀opt 数字后缀opt 负数模式: 前缀opt 数字后缀opt 前缀: 除 \uFFFE、\uFFFF 和特殊字符以外的所有 Unicode 字符 后缀: 除 \uFFFE、\uFFFF 和特殊字符以外的所有 Unicode 字符 数字: 整数指数opt 整数。小数指数opt 整数: 最小整数 # # 整数 # , 整数 最小整数: 0 0 最小整数 0 , 最小整数 小数: 最小小数opt 可选小数opt 最小小数: 0 最小小数opt 可选小数: # 可选小数opt 指数: E 最小指数 最小指数: 0 最小指数opt
DecimalFormat
模式包含正数和负数子模式,例如 "#,##0.00;(#,##0.00)"
。每个子模式都有前缀、数字部分和后缀。负数子模式是可选的;如果存在,则将用已本地化的减号(在多数语言环境中是 '-'
)作为前缀的正数子模式用作负数子模式。也就是说,单独的 "0.00"
等效于 "0.00;-0.00"
。如果存在显式的负数子模式,则它仅指定负数前缀和后缀;数字位数、最小位数,其他特征都与正数模式相同。这意味着 "#,##0.0#;(#)"
的行为与 "#,##0.0#;(#,##0.0#)"
完全相同。
用于无穷大值、数字、千位分隔符、小数分隔符等的前缀、后缀和各种符号可设置为任意值,并且能在格式化期间正确显示。但是,必须注意不要让符号和字符串发生冲突,否则分析是不可靠的。例如,为了让 DecimalFormat.parse()
能够区分正数和负数,正数和负数前缀或后缀必须是不同的。(如果它们相同,则 DecimalFormat
的行为就如同未指定负数子模式一样。)另一个示例是小数分隔符和千位分隔符应该是不同的字符,否则将不可能进行分析。
分组分隔符通常用于千位,但是在某些国家/地区中它用于分隔万位。分组大小是分组字符之间的固定数字位数,例如 100,000,000 是 3,而 1,0000,0000 则是 4。如果使用具有多个分组字符的模式,则最后一个分隔符和整数结尾之间的间隔才是使用的分组大小。所以 "#,##,###,####"
== "######,####"
== "##,####,####"
。
特殊模式字符
模式中的很多字符都是按字面解释的;在分析期间对其进行匹配,在格式化期间则不经改变地输出。另一方面,特殊字符代表了其他字符、字符串或字符类。如果要将其作为字面量出现在前缀或后缀中,那么除非另行说明,否则必须对其加引号。
下列字符用在非本地化的模式中。已本地化的模式使用从此 formatter 的 DecimalFormatSymbols
对象中获得的相应字符,这些字符已失去其特殊状态。两种例外是货币符号和引号,不将其本地化。
符号 位置 本地化? 含义 0
数字 是 阿拉伯数字 #
数字字 是 阿拉伯数字,如果不存在则显示为 0 .
数字 是 小数分隔符或货币小数分隔符 -
数字 是 减号 ,
数字 是 分组分隔符 E
数字 是 分隔科学计数法中的尾数和指数。在前缀或后缀中无需加引号。 ;
子模式边界 是 分隔正数和负数子模式 %
前缀或后缀 是 乘以 100 并显示为百分数 \u2030
前缀或后缀 是 乘以 1000 并显示为千分数 ¤
(\u00A4
)前缀或后缀 否 货币记号,由货币符号替换。如果两个同时出现,则用国际货币符号替换。如果出现在某个模式中,则使用货币小数分隔符,而不使用小数分隔符。 '
前缀或后缀 否 用于在前缀或或后缀中为特殊字符加引号,例如 "'#'#"
将 123 格式化为"#123"
。要创建单引号本身,请连续使用两个单引号:"# o''clock"
。
科学计数法
科学计数法中的数表示为一个尾数和一个 10 的几次幂的乘积,例如可将 1234 表示为 1.234 x 10^3。尾数的范围通常是 1.0 <= x < 10.0,但并非必需如此。可指示 DecimalFormat
仅通过某个模式 来格式化和分析科学计数法表示的数;目前没有创建科学计数法格式的工厂方法。在这个模式中,指数字符后面紧跟着一个或多个数字字符即指示科学计数法。示例:"0.###E0"
将数字 1234 格式化为 "1.234E3"
。
- 指数字符后面的数字位数字符数给出了最小的指数位数。没有最大值。使用本地化的减号来格式化负数指数,不 使用模式中的前缀和后缀。这就允许存在诸如
"0.###E0 m/s"
等此类的模式。 - 最小和最大整数数字位数一起进行解释:
- 如果最大整数数字位数大于其最小整数数字位数并且大于 1,则强制要求指数为最大整数数字位数的倍数,并将最小整数数字位数解释为 1。最常见的用法是生成工程计数法,其中指数是 3 的倍数,如
"##0.#####E0"
。使用此模式时,数 12345 格式化为"12.345E3"
,123456 则格式化为"123.456E3"
。 - 否则通过调整指数来得到最小整数数字位数。示例:使用
"00.###E0"
格式化 0.00123 时得到"12.3E-4"
。
- 如果最大整数数字位数大于其最小整数数字位数并且大于 1,则强制要求指数为最大整数数字位数的倍数,并将最小整数数字位数解释为 1。最常见的用法是生成工程计数法,其中指数是 3 的倍数,如
- 尾数中的有效位数是最小整数 和最大小数 位数的和,不受最大整数位数的影响。例如,使用
"##0.##E0"
格式化 12345 得到"12.3E3"
。要显示所有位数,请将有效位数计数设置为零。有效位数不会影响分析。 - 指数模式可能不包含分组分隔符。
舍入
DecimalFormat
使用 half-even 舍入(请参阅 ROUND_HALF_EVEN
)进行格式化。
阿拉伯数字
为了进行格式化,DecimalFormat
使用 DecimalFormatSymbols
对象中所定义的、从已本地化的阿拉伯数字 0 开始的 10 个连续字符作为阿拉伯数字。为了进行分析,可识别 Character.digit
所定义的这些阿拉伯数字和所有 Unicode 十进制阿拉伯数字。
特殊值
NaN
被格式化为单个字符,通常是 \uFFFD
。此字符由 DecimalFormatSymbols
对象所确定。这是惟一不使用前缀和后缀的值。
无穷大的值被格式化为单个字符,通常是 \u221E
,具有正数或负数前缀和后缀。无穷大值的字符由 DecimalFormatSymbols
对象所确定。
将负零("-0"
)分析为
- 如果
isParseBigDecimal()
为 true,则为BigDecimal(0)
, - 如果
isParseBigDecimal()
为 false 并且isParseIntegerOnly()
为 true,则为Long(0)
, - 如果
isParseBigDecimal()
和isParseIntegerOnly()
均为 false,则为Double(-0.0)
。
同步
DecimalFormat 通常不是同步的。建议为每个线程创建独立的格式实例。如果多个线程同时访问某个格式,则必须保持外部同步。
示例
// Print out a number using the localized number, integer, currency, // and percent format for each locale Locale[] locales = NumberFormat.getAvailableLocales(); double myNumber = -1234.56; NumberFormat form; for (int j=0; j<4; ++j) { System.out.println("FORMAT"); for (int i = 0; i < locales.length; ++i) { if (locales[i].getCountry().length() == 0) { continue; // Skip language-only locales } System.out.print(locales[i].getDisplayName()); switch (j) { case 0: form = NumberFormat.getInstance(locales[i]); break; case 1: form = NumberFormat.getIntegerInstance(locales[i]); break; case 2: form = NumberFormat.getCurrencyInstance(locales[i]); break; default: form = NumberFormat.getPercentInstance(locales[i]); break; } if (form instanceof DecimalFormat) { System.out.print(": " + ((DecimalFormat) form).toPattern()); } System.out.print(" -> " + form.format(myNumber)); try { System.out.println(" -> " + form.parse(form.format(myNumber))); } catch (ParseException e) {} } }
嵌套类摘要 |
---|
从类 java.text.NumberFormat 继承的嵌套类/接口 |
---|
NumberFormat.Field |
字段摘要 |
---|
从类 java.text.NumberFormat 继承的字段 |
---|
FRACTION_FIELD, INTEGER_FIELD |
构造方法摘要 | |
---|---|
DecimalFormat() 使用默认模式和默认语言环境的符号创建一个 DecimalFormat。 |
|
DecimalFormat(String pattern) 使用给定的模式和默认语言环境的符号创建一个 DecimalFormat。 |
|
DecimalFormat(String pattern, DecimalFormatSymbols symbols) 使用给定的模式和符号创建一个 DecimalFormat。 |
方法摘要 | |
---|---|
void |
applyLocalizedPattern(String pattern) 将给定的模式应用于此 Format 对象。 |
void |
applyPattern(String pattern) 将给定的模式应用于此 Format 对象。 |
Object |
clone() 标准重写;没有语义上的变化。 |
boolean |
equals(Object obj) 重写 equals |
StringBuffer |
format(double number, StringBuffer result, FieldPosition fieldPosition) 格式化一个 double 值,以生成一个字符串。 |
StringBuffer |
format(long number, StringBuffer result, FieldPosition fieldPosition) 格式化一个 long 值,以生成一个字符串。 |
StringBuffer |
format(Object number, StringBuffer toAppendTo, FieldPosition pos) 格式化一个数,并将所得文本追加到给定的字符串缓冲区。 |
AttributedCharacterIterator |
formatToCharacterIterator(Object obj) 格式化一个 Object,以生成一个 AttributedCharacterIterator 。 |
Currency |
getCurrency() 获得格式化货币值时,此十进制格式使用的货币。 |
DecimalFormatSymbols |
getDecimalFormatSymbols() 返回小数格式符号,通常程序员或用户不改变此符号。 |
int |
getGroupingSize() 返回分组大小。 |
int |
getMaximumFractionDigits() 获得某个数的小数部分中所允许的最大数字位数。 |
int |
getMaximumIntegerDigits() 获得某个数的整数部分中所允许的最大数字位数。 |
int |
getMinimumFractionDigits() 获得某个数的小数部分中所允许的最小数字位数。 |
int |
getMinimumIntegerDigits() 获得某个数的整数部分中所允许的最小数字位数。 |
int |
getMultiplier() 获得百分数、千分数和类似格式中使用的乘数。 |
String |
getNegativePrefix() 获得负数前缀。 |
String |
getNegativeSuffix() 获得负数后缀。 |
String |
getPositivePrefix() 获得正数前缀。 |
String |
getPositiveSuffix() 获得正数后缀。 |
int |
hashCode() 重写 hashCode |
boolean |
isDecimalSeparatorAlwaysShown() 允许获得整数中小数分隔符的行为。 |
boolean |
isParseBigDecimal() 返回 parse(java.lang.String, java.text.ParsePosition) 方法是否返回 BigDecimal 。 |
Number |
parse(String text, ParsePosition pos) 分析字符串中的文本,以生成一个 Number 。 |
void |
setCurrency(Currency currency) 设置格式化货币值时,此数字格式使用的货币。 |
void |
setDecimalFormatSymbols(DecimalFormatSymbols newSymbols) 设置小数格式符号,通常程序员或用户不改变此符号。 |
void |
setDecimalSeparatorAlwaysShown(boolean newValue) 允许设置整数中小数分隔符的行为。 |
void |
setGroupingSize(int newValue) 设置分组大小。 |
void |
setMaximumFractionDigits(int newValue) 设置某个数的小数部分中所允许的最大数字位数。 |
void |
setMaximumIntegerDigits(int newValue) 设置某个数字的整数部分中所允许的最大数字位数。 |
void |
setMinimumFractionDigits(int newValue) 设置某个数的小数部分中所允许的最小数字位数。 |
void |
setMinimumIntegerDigits(int newValue) 设置某个数字的整数部分中所允许的最小数字位数。 |
void |
setMultiplier(int newValue) 设置百分数、千分数和类似格式中使用的乘数。 |
void |
setNegativePrefix(String newValue) 设置负数前缀。 |
void |
setNegativeSuffix(String newValue) 设置负数后缀。 |
void |
setParseBigDecimal(boolean newValue) 设置 parse(java.lang.String, java.text.ParsePosition) 方法是否返回 BigDecimal 。 |
void |
setPositivePrefix(String newValue) 设置正数前缀。 |
void |
setPositiveSuffix(String newValue) 设置正数后缀。 |
String |
toLocalizedPattern() 合成一个表示此 Format 对象当前状态的、已本地化的模式字符串。 |
String |
toPattern() 合成一个表示此 Format 对象当前状态的模式字符串。 |
从类 java.text.Format 继承的方法 |
---|
format, parseObject |
从类 java.lang.Object 继承的方法 |
---|
finalize, getClass, notify, notifyAll, toString, wait, wait, wait |
构造方法详细信息 |
---|
DecimalFormat
public DecimalFormat()
-
使用默认模式和默认语言环境的符号创建一个 DecimalFormat。当国际化不是主要的考虑方面时,这是获得 DecimalFormat 的便捷方式。
要为给定的语言环境获得标准的格式,请对 NumberFormat 使用工厂方法,如 getNumberInstance。这些工厂方法将为给定的语言环境返回最适合的 NumberFormat 子类。
DecimalFormat
public DecimalFormat(String pattern)
-
使用给定的模式和默认语言环境的符号创建一个 DecimalFormat。当国际化不是主要的考虑方面时,这是获得 DecimalFormat 的便捷方式。
要为给定的语言环境获得标准的格式,请对 NumberFormat 使用工厂方法,如 getNumberInstance。这些工厂方法将为给定的语言环境返回最适合的 NumberFormat 子类。
- 参数:
-
pattern
- 一个非本地化的模式字符串。 - 抛出:
-
NullPointerException
- 如果pattern
为 null -
IllegalArgumentException
- 如果给定的 pattern 无效。 - 另请参见:
-
NumberFormat.getInstance()
,NumberFormat.getNumberInstance()
,NumberFormat.getCurrencyInstance()
,NumberFormat.getPercentInstance()
DecimalFormat
public DecimalFormat(String pattern, DecimalFormatSymbols symbols)
-
使用给定的模式和符号创建一个 DecimalFormat。需要完全自定义格式化的行为时使用此构造方法。
要为给定的语言环境获得标准的格式,请对 NumberFormat 使用工厂方法,如 getInstance 或 getCurrencyInstance。如果只需为标准格式进行微小的调整,则可修改 NumberFormat 工厂方法所返回的格式。
- 参数:
-
pattern
- 一个非本地化的模式字符串。 -
symbols
- 要使用的符号集 - 抛出:
-
NullPointerException
- 如果任意给定的参数为 null -
IllegalArgumentException
- 如果给定的 pattern 无效 - 另请参见:
-
NumberFormat.getInstance()
,NumberFormat.getNumberInstance()
,NumberFormat.getCurrencyInstance()
,NumberFormat.getPercentInstance()
,DecimalFormatSymbols
方法详细信息 |
---|
format
public final StringBuffer format(Object number, StringBuffer toAppendTo, FieldPosition pos)
-
格式化一个数,并将所得文本追加到给定的字符串缓冲区。该数可以是
Number
的任意子类。此实现使用所允许的最大精度。
-
- 覆盖:
-
类
NumberFormat
中的format
-
- 参数:
-
number
- 要格式化的数 -
toAppendTo
- 将格式化的文本所要追加到的StringBuffer
-
pos
- 在输入上:如果需要,是一个对齐字段。在输出上:对齐字段的偏移量。 - 返回:
-
以
toAppendTo
形式传入的值 - 抛出:
-
IllegalArgumentException
- 如果number
为 null 或不是Number
的一个实例。 -
NullPointerException
- 如果toAppendTo
或pos
为 null - 另请参见:
-
FieldPosition
format
public StringBuffer format(double number, StringBuffer result, FieldPosition fieldPosition)
- 格式化一个 double 值,以生成一个字符串。
-
- 指定者:
-
类
NumberFormat
中的format
-
- 参数:
-
number
- 要格式化的 double 值 -
result
- 将文本追加到的地方 -
fieldPosition
- 在输入上:如果需要,是一个对齐字段。在输出上:对齐字段的偏移量。 - 返回:
- 已格式化的数字字符串
- 另请参见:
-
FieldPosition
format
public StringBuffer format(long number, StringBuffer result, FieldPosition fieldPosition)
- 格式化一个 long 值,以生成一个字符串。
-
- 指定者:
-
类
NumberFormat
中的format
-
- 参数:
-
number
- 要格式化的 long 值 -
result
- 将文本追加到的地方 -
fieldPosition
- 在输入上:如果需要,是一个对齐字段。在输出上:对齐字段的偏移量。 - 返回:
- 已格式化的数字字符串
- 另请参见:
-
FieldPosition
formatToCharacterIterator
public AttributedCharacterIterator formatToCharacterIterator(Object obj)
-
格式化一个 Object,以生成一个
AttributedCharacterIterator
。可以使用返回的AttributedCharacterIterator
来生成所得 String,并确定有关所得 String 的信息。AttributedCharacterIterator 的每个属性键都是
NumberFormat.Field
类型的,属性值与属性键相同。 -
- 覆盖:
-
类
Format
中的formatToCharacterIterator
-
- 参数:
-
obj
- 要格式化的对象 - 返回:
- 描述格式化值的 AttributedCharacterIterator。
- 抛出:
-
NullPointerException
- 如果 obj 为 null。 -
IllegalArgumentException
- Format 无法格式化给定的对象时。 - 从以下版本开始:
- 1.4
parse
public Number parse(String text, ParsePosition pos)
-
分析字符串中的文本,以生成一个
Number
。该方法试图分析从
pos
所给定的索引处开始的文本。如果分析成功,则将pos
的索引更新为所用最后一个字符后面的索引(不一定分析直到字符串末尾的所有字符),并返回分析后的数。可以使用更新后的pos
指示下一次调用此方法的开始点。如果发生错误,则不更改pos
的索引,并将pos
的错误索引设置为发生错误处的字符索引,并且返回 null。返回的子类取决于
isParseBigDecimal()
的值以及所分析的字符串。- 如果
isParseBigDecimal()
为 false(默认值),则以Long
对象返回多数整数值,而不管其写入方式如何:"17"
和"17.000"
都分析成Long(17)
。不符合Long
的值则以Double
的形式返回。这包括有小数部分的值、无穷大的值、NaN
和值 -0.0。DecimalFormat
不 根据源字符串中是否有小数分隔符来决定返回Double
还是Long
值。这样做会无法准确地分析导致某个 double 尾数(如"-9,223,372,036,854,775,808.00"
)溢出的整数。调用方可能使用
Number
的方法doubleValue
、longValue
等来获得所需类型的数值。 - 如果
isParseBigDecimal()
为 true,则以BigDecimal
对象的形式返回值。这些值是由BigDecimal.BigDecimal(String)
以和语言环境无关的格式为相应字符串所构造的那些值。特殊的情况是正负无穷大和 NaN 值,它们以Double
实例的形式返回,其中保存了相应的Double
常量值。
DecimalFormat
分析所有由Character.digit()
所定义的、表示小数数字的 Unicode 字符。另外,DecimalFormat
也将DecimalFormatSymbols
对象中所定义的、从已本地化的阿拉伯数字 0 开始的 10 个连续字符识别为阿拉伯数字。 - 如果
-
- 指定者:
-
类
NumberFormat
中的parse
-
- 参数:
-
text
- 要分析的字符串 -
pos
- 具有索引和上述错误索引信息的ParsePosition
对象。 - 返回:
-
分析得到的值,如果分析失败,则为
null
- 抛出:
-
NullPointerException
- 如果text
或pos
为 null。 - 另请参见:
-
NumberFormat.isParseIntegerOnly()
,Format.parseObject(java.lang.String, java.text.ParsePosition)