NumberFormat / DecimalFormat似乎无法将具有"#.0"
格式(其中#是任何数字)的字符串解析为双精度型。
以下代码说明了这一点:
#include <cstdio>
#include <iostream>
#include <unicode/decimfmt.h>
#include <unicode/numfmt.h>
#include <unicode/unistr.h>
#include <unicode/ustream.h>
int main() {
UErrorCode status = U_ZERO_ERROR;
// DecimalFormat doesn't work either
NumberFormat* f = NumberFormat::createInstance(status);
f->setGroupingUsed(false);
f->setParseIntegerOnly(false);
UnicodeString str("2.0"); // Change to "2.#" for it to work, where # is any non-zero number
Formattable formattable;
f->parse(str, formattable, status);
if (U_FAILURE(status)) {
printf("ERROR: %s\n", u_errorName(status));
delete f;
return 1;
} else {
if (formattable.getType() == Formattable::kDouble) {
printf("kDouble: %f\n", formattable.getDouble());
} else if ((formattable.getType() == Formattable::kLong)) {
printf("kLong: %d\n", formattable.getLong());
} else {
printf("ERROR: unexpected type: %d\n", formattable.getType());
}
}
str.remove(); // Clear the string
f->format(2.0f, str);
std::cout << "formatted: \"" << str << '\"' << std::endl; // Outputs "2"
delete f;
return 0;
}
解析
"2.0"
时,格式表的类型为2(Formattable::Type::kLong
)。解析"2.1"
时,Formattable的类型为1(Formattable:Type::kDouble
)-对于两个字符串都应该如此。当您尝试将浮点格式格式化为UnicodeString时,也会出现问题(例如,将浮点
2.0
格式化为"2"
)。因此:如何在不将双精度数解释为ICU中的整数的情况下解析/格式化任何双精度数?
最佳答案
您可以调用formattable.getDouble(status)
-getType返回long的唯一原因是特定值适合long。
至于格式,如果在格式之前调用f->setMinimumFractionDigits(1);
,则代码将获得“ 2.0”,将最小位数设置为2将得到“ 2.00”,依此类推。
hth