#include "unicode/utypes.h"
#include "unicode/uloc.h"
#include "unicode/umisc.h"
#include "unicode/parseerr.h"
Go to the source code of this file.
Defines | |
#define | UNFSYMBOLSMAXSIZE 10 |
The maximum size for a textual number format symbol. | |
Typedefs | |
typedef void * | UNumberFormat |
A number formatter. | |
typedef enum UNumberFormatStyle | UNumberFormatStyle |
The possible number format styles. | |
typedef enum UNumberFormatRoundingMode | UNumberFormatRoundingMode |
The possible number format rounding modes. | |
typedef enum UNumberFormatPadPosition | UNumberFormatPadPosition |
The possible number format pad positions. | |
typedef enum UNumberFormatAttribute | UNumberFormatAttribute |
The possible UNumberFormat numeric attributes ICU 2.0. | |
typedef enum UNumberFormatTextAttribute | UNumberFormatTextAttribute |
The possible UNumberFormat text attributes ICU 2.0. | |
typedef enum UNumberFormatSymbol | UNumberFormatSymbol |
Constants for specifying a number format symbol. | |
Enumerations | |
enum | UNumberFormatStyle { UNUM_IGNORE = 0, UNUM_DECIMAL = 1, UNUM_CURRENCY, UNUM_PERCENT, UNUM_SCIENTIFIC, UNUM_SPELLOUT, UNUM_DEFAULT = UNUM_DECIMAL } |
The possible number format styles. More... | |
enum | UNumberFormatRoundingMode { UNUM_ROUND_CEILING, UNUM_ROUND_FLOOR, UNUM_ROUND_DOWN, UNUM_ROUND_UP, UNUM_FOUND_HALFEVEN, UNUM_ROUND_HALFDOWN, UNUM_ROUND_HALFUP } |
The possible number format rounding modes. More... | |
enum | UNumberFormatPadPosition { UNUM_PAD_BEFORE_PREFIX, UNUM_PAD_AFTER_PREFIX, UNUM_PAD_BEFORE_SUFFIX, UNUM_PAD_AFTER_SUFFIX } |
The possible number format pad positions. More... | |
enum | UNumberFormatAttribute { UNUM_PARSE_INT_ONLY, UNUM_GROUPING_USED, UNUM_DECIMAL_ALWAYS_SHOWN, UNUM_MAX_INTEGER_DIGITS, UNUM_MIN_INTEGER_DIGITS, UNUM_INTEGER_DIGITS, UNUM_MAX_FRACTION_DIGITS, UNUM_MIN_FRACTION_DIGITS, UNUM_FRACTION_DIGITS, UNUM_MULTIPLIER, UNUM_GROUPING_SIZE, UNUM_ROUNDING_MODE, UNUM_ROUNDING_INCREMENT, UNUM_FORMAT_WIDTH, UNUM_PADDING_POSITION, UNUM_SECONDARY_GROUPING_SIZE } |
The possible UNumberFormat numeric attributes ICU 2.0. More... | |
enum | UNumberFormatTextAttribute { UNUM_POSITIVE_PREFIX, UNUM_POSITIVE_SUFFIX, UNUM_NEGATIVE_PREFIX, UNUM_NEGATIVE_SUFFIX, UNUM_PADDING_CHARACTER, UNUM_CURRENCY_CODE } |
The possible UNumberFormat text attributes ICU 2.0. More... | |
enum | UNumberFormatSymbol { UNUM_DECIMAL_SEPARATOR_SYMBOL, UNUM_GROUPING_SEPARATOR_SYMBOL, UNUM_PATTERN_SEPARATOR_SYMBOL, UNUM_PERCENT_SYMBOL, UNUM_ZERO_DIGIT_SYMBOL, UNUM_DIGIT_SYMBOL, UNUM_MINUS_SIGN_SYMBOL, UNUM_PLUS_SIGN_SYMBOL, UNUM_CURRENCY_SYMBOL, UNUM_INTL_CURRENCY_SYMBOL, UNUM_MONETARY_SEPARATOR_SYMBOL, UNUM_EXPONENTIAL_SYMBOL, UNUM_PERMILL_SYMBOL, UNUM_PAD_ESCAPE_SYMBOL, UNUM_INFINITY_SYMBOL, UNUM_NAN_SYMBOL, UNUM_FORMAT_SYMBOL_COUNT } |
Constants for specifying a number format symbol. More... | |
Functions | |
U_CAPI UNumberFormat *U_EXPORT2 | unum_open (UNumberFormatStyle style, const UChar *pattern, int32_t patternLength, const char *locale, UParseError *parseErr, UErrorCode *status) |
Open a new UNumberFormat for formatting and parsing numbers. | |
U_CAPI void U_EXPORT2 | unum_close (UNumberFormat *fmt) |
Close a UNumberFormat. | |
U_CAPI UNumberFormat *U_EXPORT2 | unum_clone (const UNumberFormat *fmt, UErrorCode *status) |
Open a copy of a UNumberFormat. | |
U_CAPI int32_t U_EXPORT2 | unum_format (const UNumberFormat *fmt, int32_t number, UChar *result, int32_t resultLength, UFieldPosition *pos, UErrorCode *status) |
Format an integer using a UNumberFormat. | |
U_CAPI int32_t U_EXPORT2 | unum_formatInt64 (const UNumberFormat *fmt, int64_t number, UChar *result, int32_t resultLength, UFieldPosition *pos, UErrorCode *status) |
Format an int64 using a UNumberFormat. | |
U_CAPI int32_t U_EXPORT2 | unum_formatDouble (const UNumberFormat *fmt, double number, UChar *result, int32_t resultLength, UFieldPosition *pos, UErrorCode *status) |
Format a double using a UNumberFormat. | |
U_CAPI int32_t U_EXPORT2 | unum_parse (const UNumberFormat *fmt, const UChar *text, int32_t textLength, int32_t *parsePos, UErrorCode *status) |
Parse a string into an integer using a UNumberFormat. | |
U_CAPI int64_t U_EXPORT2 | unum_parseInt64 (const UNumberFormat *fmt, const UChar *text, int32_t textLength, int32_t *parsePos, UErrorCode *status) |
Parse a string into an int64 using a UNumberFormat. | |
U_CAPI double U_EXPORT2 | unum_parseDouble (const UNumberFormat *fmt, const UChar *text, int32_t textLength, int32_t *parsePos, UErrorCode *status) |
Parse a string into a double using a UNumberFormat. | |
U_CAPI void U_EXPORT2 | unum_applyPattern (UNumberFormat *format, UBool localized, const UChar *pattern, int32_t patternLength, UParseError *parseError, UErrorCode *status) |
Set the pattern used by an UNumberFormat. | |
U_CAPI const char *U_EXPORT2 | unum_getAvailable (int32_t index) |
Get a locale for which number formatting patterns are available. | |
U_CAPI int32_t U_EXPORT2 | unum_countAvailable (void) |
Determine how many locales have number formatting patterns available. | |
U_CAPI int32_t U_EXPORT2 | unum_getAttribute (const UNumberFormat *fmt, UNumberFormatAttribute attr) |
Get a numeric attribute associated with a UNumberFormat. | |
U_CAPI void U_EXPORT2 | unum_setAttribute (UNumberFormat *fmt, UNumberFormatAttribute attr, int32_t newValue) |
Set a numeric attribute associated with a UNumberFormat. | |
U_CAPI double U_EXPORT2 | unum_getDoubleAttribute (const UNumberFormat *fmt, UNumberFormatAttribute attr) |
Get a numeric attribute associated with a UNumberFormat. | |
U_CAPI void U_EXPORT2 | unum_setDoubleAttribute (UNumberFormat *fmt, UNumberFormatAttribute attr, double newValue) |
Set a numeric attribute associated with a UNumberFormat. | |
U_CAPI int32_t U_EXPORT2 | unum_getTextAttribute (const UNumberFormat *fmt, UNumberFormatTextAttribute tag, UChar *result, int32_t resultLength, UErrorCode *status) |
Get a text attribute associated with a UNumberFormat. | |
U_CAPI void U_EXPORT2 | unum_setTextAttribute (UNumberFormat *fmt, UNumberFormatTextAttribute tag, const UChar *newValue, int32_t newValueLength, UErrorCode *status) |
Set a text attribute associated with a UNumberFormat. | |
U_CAPI int32_t U_EXPORT2 | unum_toPattern (const UNumberFormat *fmt, UBool isPatternLocalized, UChar *result, int32_t resultLength, UErrorCode *status) |
Extract the pattern from a UNumberFormat. | |
U_CAPI int32_t U_EXPORT2 | unum_getSymbol (UNumberFormat *fmt, UNumberFormatSymbol symbol, UChar *buffer, int32_t size, UErrorCode *status) |
Get a symbol associated with a UNumberFormat. | |
U_CAPI void U_EXPORT2 | unum_setSymbol (UNumberFormat *fmt, UNumberFormatSymbol symbol, const UChar *value, int32_t length, UErrorCode *status) |
Set a symbol associated with a UNumberFormat. | |
U_CAPI const char *U_EXPORT2 | unum_getLocaleByType (const UNumberFormat *fmt, ULocDataLocaleType type, UErrorCode *status) |
Get the locale for this number format object. |
Number Format C API Provides functions for formatting and parsing a number. Also provides methods for determining which locales have number formats, and what their names are.
UNumberFormat helps you to format and parse numbers for any locale. Your code can be completely independent of the locale conventions for decimal points, thousands-separators, or even the particular decimal digits used, or whether the number format is even decimal. There are different number format styles like decimal, currency, percent and spellout.
To format a number for the current Locale, use one of the static factory methods:
If you are formatting multiple numbers, it is more efficient to get the format and use it multiple times so that the system doesn't have to fetch the information about the local language and country conventions multiple times.UChar myString[20]; double myNumber = 7.0; UErrorCode status = U_ZERO_ERROR; UNumberFormat* nf = unum_open(UNUM_DEFAULT, NULL, -1, NULL, NULL, &status); unum_formatDouble(nf, myNumber, myString, 20, NULL, &status); printf(" Example 1: %s\n", austrdup(myString) ); //austrdup( a function used to convert UChar* to char*)
To format a number for a different Locale, specify it in the call to unum_open().uint32_t i, resultlength, reslenneeded; UErrorCode status = U_ZERO_ERROR; UFieldPosition pos; uint32_t a[] = { 123, 3333, -1234567 }; const uint32_t a_len = sizeof(a) / sizeof(a[0]); UNumberFormat* nf; UChar* result = NULL; nf = unum_open(UNUM_DEFAULT, NULL, -1, NULL, NULL, &status); for (i = 0; i < a_len; i++) { resultlength=0; reslenneeded=unum_format(nf, a[i], NULL, resultlength, &pos, &status); result = NULL; if(status==U_BUFFER_OVERFLOW_ERROR){ status=U_ZERO_ERROR; resultlength=reslenneeded+1; result=(UChar*)malloc(sizeof(UChar) * resultlength); unum_format(nf, a[i], result, resultlength, &pos, &status); } printf( " Example 2: %s\n", austrdup(result)); free(result); }
You can use a NumberFormat API unum_parse() to parse.
Use UCAL_DECIMAL to get the normal number format for that country. There are other static options available. Use UCAL_CURRENCY to get the currency number format for that country. Use UCAL_PERCENT to get a format for displaying percentages. With this format, a fraction from 0.53 is displayed as 53%.UErrorCode status = U_ZERO_ERROR; int32_t pos=0; int32_t num; num = unum_parse(nf, str, u_strlen(str), &pos, &status);
You can also control the display of numbers with such function as unum_getAttribues() and unum_setAtributes(). where in you can set the miminum fraction digits, grouping used etc.
It is also possible to change or set the symbols used for a particular locale like the currency symbol, the grouping seperator , monetary seperator etc by making use of functions unum_setSymbols() and unum_getSymbols().
|
The maximum size for a textual number format symbol.
For internal use only.
|
|
A number formatter. For usage in C programs. ICU 2.0 |
|
The possible number format pad positions. ICU 2.0 |
|
The possible number format rounding modes. ICU 2.0 |
|
The possible number format styles. ICU 2.0 |
|
Constants for specifying a number format symbol. ICU 2.0 |
|
|
The possible number format pad positions. ICU 2.0 |
|
The possible number format rounding modes. ICU 2.0 |
|
The possible number format styles. ICU 2.0 |
|
Constants for specifying a number format symbol. ICU 2.0
|
|
The possible UNumberFormat text attributes ICU 2.0.
|
|
Set the pattern used by an UNumberFormat. The pattern should follow the pattern syntax rules.
|
|
Open a copy of a UNumberFormat. This function performs a deep copy.
|
|
Close a UNumberFormat. Once closed, a UNumberFormat may no longer be used.
|
|
Determine how many locales have number formatting patterns available. This function is most useful as determining the loop ending condition for calls to {unum_getAvailable}.
|
|
Format an integer using a UNumberFormat. The integer will be formatted according to the UNumberFormat's locale.
|
|
Format a double using a UNumberFormat. The double will be formatted according to the UNumberFormat's locale.
|
|
Format an int64 using a UNumberFormat. The int64 will be formatted according to the UNumberFormat's locale.
|
|
Get a numeric attribute associated with a UNumberFormat. An example of a numeric attribute is the number of integer digits a formatter will produce.
|
|
Get a locale for which number formatting patterns are available. A UNumberFormat in a locale returned by this function will perform the correct formatting and parsing for the locale.
|
|
Get a numeric attribute associated with a UNumberFormat. An example of a numeric attribute is the number of integer digits a formatter will produce.
|
|
Get the locale for this number format object. You can choose between valid and actual locale.
|
|
Get a symbol associated with a UNumberFormat. A UNumberFormat uses symbols to represent the special locale-dependent characters in a number, for example the percent sign.
|
|
Get a text attribute associated with a UNumberFormat. An example of a text attribute is the suffix for positive numbers.
|
|
Open a new UNumberFormat for formatting and parsing numbers. A UNumberFormat may be used to format numbers in calls to {unum_format}, and to parse numbers in calls to {unum_parse}.
|
|
Parse a string into an integer using a UNumberFormat. The string will be parsed according to the UNumberFormat's locale.
|
|
Parse a string into a double using a UNumberFormat. The string will be parsed according to the UNumberFormat's locale.
|
|
Parse a string into an int64 using a UNumberFormat. The string will be parsed according to the UNumberFormat's locale.
|
|
Set a numeric attribute associated with a UNumberFormat. An example of a numeric attribute is the number of integer digits a formatter will produce.
|
|
Set a numeric attribute associated with a UNumberFormat. An example of a numeric attribute is the number of integer digits a formatter will produce.
|
|
Set a symbol associated with a UNumberFormat. A UNumberFormat uses symbols to represent the special locale-dependent characters in a number, for example the percent sign.
|
|
Set a text attribute associated with a UNumberFormat. An example of a text attribute is the suffix for positive numbers.
|
|
Extract the pattern from a UNumberFormat. The pattern will follow the pattern syntax.
|