我目前正在使用:
....
for (int i = 0; i < 3; i++) {
data = data + ";" + String.format("%.8f", values.toArray()[i]);
}
...
captureFile.println( data );
但我需要根据用户的偏好更改小数分隔符,而不是在区域设置(应用程序是英文的,但日志分析器可以使用Excel法语版本…
if (decimalSeparatorDot)
// use current format ( US ) dot
else
// String format with comma
thanks for help
是否有一种方法可以轻松地做到这一点,或者我应该改变我的字符串。
我试过NumberFormat如下:
NumberFormat nf;
boolean dot = false;
if (dot) {
nf = NumberFormat.getInstance(Locale.US);
((DecimalFormat) nf).applyPattern("#0.00000000");
} else {
nf = NumberFormat.getInstance(Locale.FRENCH);
((DecimalFormat) nf).applyPattern("#0,00000000");
}
...
for (int i = 0; i < 3; i++) { data = data + ";" + nf.format(values.toArray()[i]); }
it's working fine when dot is true ( current app Locale US ..) but it's giving all values to 0,000000000 when dot is false ( french)
我不知道这是不是最好的方法,但是现在使用:
NumberFormat nf= null;
try {
if (decimaSeparator == "dot") {
nf = NumberFormat.getInstance(Locale.US);
nf.setMinimumFractionDigits(8);
nf.setMaximumFractionDigits(8);
} else { // comma
nf = NumberFormat.getInstance(Locale.FRENCH);
nf.setMinimumFractionDigits(8);
nf.setMaximumFractionDigits(8);
}
}
catch (ClassCastException e) {
System.err.println(e);
}
试试这个…
DecimalFormat df = new DecimalFormat();
DecimalFormatSymbols dfs = new DecimalFormatSymbols();
dfs.setDecimalSeparator(','); // Set as dot or comma
df.setDecimalFormatSymbols(dfs);
使用十进制格式:
val formatter = DecimalFormat().apply {
val dfs = DecimalFormatSymbols().apply {
decimalSeparator = ','
groupingSeparator = '.'
}
decimalFormatSymbols = dfs
}
return formatter.format(value)