All Packages Class Hierarchy This Package Previous Next Index
Class java.text.DecimalFormat
java.lang.Object
|
+----java.text.Format
|
+----java.text.NumberFormat
|
+----java.text.DecimalFormat
- public class DecimalFormat
- extends NumberFormat
DecimalFormat
is a concrete subclass of NumberFormat
for formatting decimal numbers. This class allows for a variety
of parameters, and localization to Western, Arabic, or Indic numbers.
Normally, you get the proper NumberFormat
for a specific
locale (including the default locale) using one of NumberFormat
's
factory methods such as getInstance
. You may then modify it
from there (after testing to make sure it is a DecimalFormat
,
of course!)
Either the prefixes or the suffixes must be different for
the parse to distinguish positive from negative.
Parsing will be unreliable if the digits, thousands or decimal separators
are the same, or if any of them occur in the prefixes or suffixes.
Special cases:
NaN
is formatted as a single character, typically
\\uFFFD
.
+/-Infinity is formatted as a single character, typically \\u221E
,
plus the positive and negative pre/suffixes.
Note:
this class is designed for common users; for very
large or small numbers, use a format that can express exponential values.
Example:
// normally we would have a GUI with a menu for this
Locale[] locales = NumberFormat.getAvailableLocales();
double myNumber = -1234.56;
NumberFormat form;
// just for fun, we print out a number with the locale number, currency
// and percent format for each locale we can.
for (int j = 0; j < 3; ++j) {
System.out.println("FORMAT");
for (int i = 0; i < locales.length; ++i) {
if (locales[i].getCountry().length() == 0) {
// skip language-only
continue;
}
System.out.print(locales[i].getDisplayName());
switch (j) {
default:
form = NumberFormat.getInstance(locales[i]); break;
case 1:
form = NumberFormat.getCurrencyInstance(locales[i]); break;
case 0:
form = NumberFormat.getPercentInstance(locales[i]); break;
}
try {
System.out.print(": " + ((DecimalFormat)form).toPattern()
+ " -> " + form.format(myNumber));
} catch (IllegalArgumentException iae) { }
try {
System.out.println(" -> " + form.parse(form.format(myNumber)));
} catch (ParseException pe) { }
}
}
The following shows the structure of the pattern.
pattern := subpattern{;subpattern}
subpattern := {prefix}integer{.fraction}{suffix}
prefix := '\\u0000'..'\\uFFFD' - specialCharacters
suffix := '\\u0000'..'\\uFFFD' - specialCharacters
integer := '#'* '0'* '0'
fraction := '0'* '#'*
Notation:
X* 0 or more instances of X
(X | Y) either X or Y.
X..Y any character from X up to Y, inclusive.
S - T characters in S, except those in T
The first subpattern is for positive numbers. The second (optional)
subpattern is for negative numbers. (In both cases, ',' can occur
inside the integer portion--it is just too messy to indicate in BNF.)
Here are the special characters used in the parts of the
subpattern, with notes on their usage.
Symbol Meaning
0 a digit
# a digit, zero shows as absent
. placeholder for decimal separator
, placeholder for grouping separator.
; separates formats.
- default negative prefix.
% divide by 100 and show as percentage
X any other characters can be used in the prefix or suffix
' used to quote special characters in a prefix or suffix.
Notes
If there is no explicit negative subpattern, - is prefixed to the
positive form. That is, "0.00" alone is equivalent to "0.00;-0.00".
Illegal formats, such as "#.#.#" or mixing '_' and '*' in the
same format, will cause an ParseException
to be thrown.
From that ParseException
, you can find the place in the string
where the error occurred.
The grouping separator is commonly used for thousands, but in some
countries for ten-thousands. The interval is a constant number of
digits between the grouping characters, such as 100,000,000 or 1,0000,0000.
If you supply a pattern with multiple grouping characters, the interval
between the last one and the end of the integer is the one that is
used. So "#,##,###,####" == "######,####" == "##,####,####".
This class only handles localized digits where the 10 digits
are contiguous in Unicode, from 0 to 9. Other digits sets
(such as superscripts) would need a different subclass.
- See Also:
- Format, NumberFormat, ChoiceFormat
-
DecimalFormat()
- Create a DecimalFormat using the default pattern and symbols
for the default locale.
-
DecimalFormat(String)
- Create a DecimalFormat from the given pattern and the symbols
for the default locale.
-
DecimalFormat(String, DecimalFormatSymbols)
- Create a DecimalFormat from the given pattern and symbols.
-
applyLocalizedPattern(String)
- Apply the given pattern to this Format object.
-
applyPattern(String)
- Apply the given pattern to this Format object.
-
clone()
- Standard override; no change in semantics.
-
equals(Object)
- Overrides equals
-
format(double, StringBuffer, FieldPosition)
- Specialization of format.
-
format(long, StringBuffer, FieldPosition)
- Specialization of format.
-
getDecimalFormatSymbols()
- Returns the decimal format symbols, which is generally not changed
by the programmer or user.
-
getGroupingSize()
- Return the grouping size.
-
getMultiplier()
- Get the multiplier for use in percent, permill, etc.
-
getNegativePrefix()
- Get the negative prefix.
-
getNegativeSuffix()
- Get the negative suffix.
-
getPositivePrefix()
- Get the positive prefix.
-
getPositiveSuffix()
- Get the positive suffix.
-
hashCode()
- Overrides hashCode
-
isDecimalSeparatorAlwaysShown()
- Allows you to get the behavior of the decimal separator with integers.
-
parse(String, ParsePosition)
- Returns a Long if possible (e.g.
-
setDecimalFormatSymbols(DecimalFormatSymbols)
- Sets the decimal format symbols, which is generally not changed
by the programmer or user.
-
setDecimalSeparatorAlwaysShown(boolean)
- Allows you to set the behavior of the decimal separator with integers.
-
setGroupingSize(int)
- Set the grouping size.
-
setMultiplier(int)
- Set the multiplier for use in percent, permill, etc.
-
setNegativePrefix(String)
- Set the negative prefix.
-
setNegativeSuffix(String)
- Set the positive suffix.
-
setPositivePrefix(String)
- Set the positive prefix.
-
setPositiveSuffix(String)
- Set the positive suffix.
-
toLocalizedPattern()
- Synthesizes a localized pattern string that represents the current
state of this Format object.
-
toPattern()
- Synthesizes a pattern string that represents the current state
of this Format object.
DecimalFormat
public DecimalFormat()
- Create a DecimalFormat using the default pattern and symbols
for the default locale. This is a convenient way to obtain a
DecimalFormat when internationalization is not the main concern.
To obtain standard formats for a given locale, use the factory methods
on NumberFormat such as getNumberInstance. These factories will
return the most appropriate sub-class of NumberFormat for a given
locale.
- See Also:
- getInstance, getNumberInstance, getCurrencyInstance, getPercentInstance
DecimalFormat
public DecimalFormat(String pattern)
- Create a DecimalFormat from the given pattern and the symbols
for the default locale. This is a convenient way to obtain a
DecimalFormat when internationalization is not the main concern.
To obtain standard formats for a given locale, use the factory methods
on NumberFormat such as getNumberInstance. These factories will
return the most appropriate sub-class of NumberFormat for a given
locale.
- Parameters:
- pattern - A non-localized pattern string.
- Throws: IllegalArgumentException
- if the given pattern is invalid.
- See Also:
- getInstance, getNumberInstance, getCurrencyInstance, getPercentInstance
DecimalFormat
public DecimalFormat(String pattern,
DecimalFormatSymbols symbols)
- Create a DecimalFormat from the given pattern and symbols.
Use this constructor when you need to completely customize the
behavior of the format.
To obtain standard formats for a given
locale, use the factory methods on NumberFormat such as
getInstance or getCurrencyInstance. If you need only minor adjustments
to a standard format, you can modify the format returned by
a NumberFormat factory method.
- Parameters:
- pattern - a non-localized pattern string
- symbols - the set of symbols to be used
- Throws: IllegalArgumentException
- if the given pattern is invalid
- See Also:
- getInstance, getNumberInstance, getCurrencyInstance, getPercentInstance, DecimalFormatSymbols
format
public StringBuffer format(double number,
StringBuffer result,
FieldPosition fieldPosition)
- Specialization of format.
- Overrides:
- format in class NumberFormat
format
public StringBuffer format(long number,
StringBuffer result,
FieldPosition fieldPosition)
- Specialization of format.
- Overrides:
- format in class NumberFormat
parse
public Number parse(String text,
ParsePosition status)
- Returns a Long if possible (e.g.
- Overrides:
- parse in class NumberFormat
getDecimalFormatSymbols
public DecimalFormatSymbols getDecimalFormatSymbols()
- Returns the decimal format symbols, which is generally not changed
by the programmer or user.
- Returns:
- desired DecimalFormatSymbols
- See Also:
- DecimalFormatSymbols
setDecimalFormatSymbols
public void setDecimalFormatSymbols(DecimalFormatSymbols newSymbols)
- Sets the decimal format symbols, which is generally not changed
by the programmer or user.
- Parameters:
- newSymbols - desired DecimalFormatSymbols
- See Also:
- DecimalFormatSymbols
getPositivePrefix
public String getPositivePrefix()
- Get the positive prefix.
Examples: +123, $123, sFr123
setPositivePrefix
public void setPositivePrefix(String newValue)
- Set the positive prefix.
Examples: +123, $123, sFr123
getNegativePrefix
public String getNegativePrefix()
- Get the negative prefix.
Examples: -123, ($123) (with negative suffix), sFr-123
setNegativePrefix
public void setNegativePrefix(String newValue)
- Set the negative prefix.
Examples: -123, ($123) (with negative suffix), sFr-123
getPositiveSuffix
public String getPositiveSuffix()
- Get the positive suffix.
Example: 123%
setPositiveSuffix
public void setPositiveSuffix(String newValue)
- Set the positive suffix.
Example: 123%
getNegativeSuffix
public String getNegativeSuffix()
- Get the negative suffix.
Examples: -123%, ($123) (with positive suffixes)
setNegativeSuffix
public void setNegativeSuffix(String newValue)
- Set the positive suffix.
Examples: 123%
getMultiplier
public int getMultiplier()
- Get the multiplier for use in percent, permill, etc.
For a percentage, set the suffixes to have "%" and the multiplier to be 100.
(For Arabic, use arabic percent symbol).
For a permill, set the suffixes to have "?" and the multiplier to be 1000.
Examples: with 100, 1.23 -> "123", and "123" -> 1.23
setMultiplier
public void setMultiplier(int newValue)
- Set the multiplier for use in percent, permill, etc.
For a percentage, set the suffixes to have "%" and the multiplier to be 100.
(For Arabic, use arabic percent symbol).
For a permill, set the suffixes to have "?" and the multiplier to be 1000.
Examples: with 100, 1.23 -> "123", and "123" -> 1.23
getGroupingSize
public int getGroupingSize()
- Return the grouping size. Grouping size is the number of digits between
grouping separators in the integer portion of a number. For example,
in the number "123,456.78", the grouping size is 3.
- See Also:
- setGroupingSize, isGroupingUsed, getGroupingSeparator
setGroupingSize
public void setGroupingSize(int newValue)
- Set the grouping size. Grouping size is the number of digits between
grouping separators in the integer portion of a number. For example,
in the number "123,456.78", the grouping size is 3.
- See Also:
- getGroupingSize, setGroupingUsed, setGroupingSeparator
isDecimalSeparatorAlwaysShown
public boolean isDecimalSeparatorAlwaysShown()
- Allows you to get the behavior of the decimal separator with integers.
(The decimal separator will always appear with decimals.)
Example: Decimal ON: 12345 -> 12345.; OFF: 12345 -> 12345
setDecimalSeparatorAlwaysShown
public void setDecimalSeparatorAlwaysShown(boolean newValue)
- Allows you to set the behavior of the decimal separator with integers.
(The decimal separator will always appear with decimals.)
Example: Decimal ON: 12345 -> 12345.; OFF: 12345 -> 12345
clone
public Object clone()
- Standard override; no change in semantics.
- Overrides:
- clone in class NumberFormat
equals
public boolean equals(Object obj)
- Overrides equals
- Overrides:
- equals in class NumberFormat
hashCode
public int hashCode()
- Overrides hashCode
- Overrides:
- hashCode in class NumberFormat
toPattern
public String toPattern()
- Synthesizes a pattern string that represents the current state
of this Format object.
- See Also:
- applyPattern
toLocalizedPattern
public String toLocalizedPattern()
- Synthesizes a localized pattern string that represents the current
state of this Format object.
- See Also:
- applyPattern
applyPattern
public void applyPattern(String pattern)
- Apply the given pattern to this Format object. A pattern is a
short-hand specification for the various formatting properties.
These properties can also be changed individually through the
various setter methods.
There is no limit to integer digits are set
by this routine, since that is the typical end-user desire;
use setMaximumInteger if you want to set a real value.
For negative numbers, use a second pattern, separated by a semicolon
Example "#,#00.0#" -> 1,234.56
This means a minimum of 2 integer digits, 1 fraction digit, and
a maximum of 2 fraction digits.
Example: "#,#00.0#;(#,#00.0#)" for negatives in parantheses.
In negative patterns, the minimum and maximum counts are ignored;
these are presumed to be set in the positive pattern.
applyLocalizedPattern
public void applyLocalizedPattern(String pattern)
- Apply the given pattern to this Format object. The pattern
is assumed to be in a localized notation. A pattern is a
short-hand specification for the various formatting properties.
These properties can also be changed individually through the
various setter methods.
There is no limit to integer digits are set
by this routine, since that is the typical end-user desire;
use setMaximumInteger if you want to set a real value.
For negative numbers, use a second pattern, separated by a semicolon
Example "#,#00.0#" -> 1,234.56
This means a minimum of 2 integer digits, 1 fraction digit, and
a maximum of 2 fraction digits.
Example: "#,#00.0#;(#,#00.0#)" for negatives in parantheses.
In negative patterns, the minimum and maximum counts are ignored;
these are presumed to be set in the positive pattern.
All Packages Class Hierarchy This Package Previous Next Index
Submit a bug or feature