我正在尝试以科学格式格式化一些大数字,但我需要三的倍数的力量。有推荐的方法吗?
我在表格中有一系列数字,而不是真正的科学格式(小数点前有一个数字),我很高兴能够进行这种更改,以便获得三的倍数,例如:
3.123e+003
19.523e+003
而不是:
3.123e+003
1.952e+004
我相信,拥有所有三的倍数会使我的表格更容易扫描。
提前致谢
我正在尝试以科学格式格式化一些大数字,但我需要三的倍数的力量。有推荐的方法吗?
我在表格中有一系列数字,而不是真正的科学格式(小数点前有一个数字),我很高兴能够进行这种更改,以便获得三的倍数,例如:
3.123e+003
19.523e+003
而不是:
3.123e+003
1.952e+004
我相信,拥有所有三的倍数会使我的表格更容易扫描。
提前致谢
我认为您需要编写自己的函数。首先,您可以获得数字的科学表示,其精度比您需要的大两位数。然后你应该解析结果字符串以获得浮点系数和 10 的幂指数作为十进制类型的数字。之后,您将除法索引的其余部分分析为 3,并以适当的方式更改数字。最后生成输出字符串。
static string Scientific3(double value, int precision)
{
string fstr1 = "{0:E" + (precision+2).ToString() + "}";
string step1 = string.Format(fstr1, value);
int index1 = step1.ToLower().IndexOf('e');
if (index1 < 0 || index1 == step1.Length - 1)
throw new Exception();
decimal coeff = Convert.ToDecimal(step1.Substring(0, index1));
int index = Convert.ToInt32(step1.Substring(index1 + 1));
while(index%3!=0)
{
index--;
coeff *= 10;
}
string fstr2 = "{0:F" + precision.ToString() + "}E{1}{2:D3}";
return string.Format(fstr2, coeff, ((index < 0) ? "-" : "+"), Math.Abs(index));
}