gpt4 book ai didi

c# - 没有科学记数法的 double 字符串转换

转载 作者:IT王子 更新时间:2023-10-29 03:42:51 26 4
gpt4 key购买 nike

如何在 .NET Framework 中将 double 转换为不带科学记数法的浮点字符串表示形式?

“小”样本(有效数字可以是任何大小,例如 1.5E2001e-200):

3248971234698200000000000000000000000000000000
0.00000000000000000000000000000000000023897356978234562

standard number formats 都不是这样的,而且 custom format 似乎也不允许在小数点后有一个开放数字。

这不是 How to convert double to string without the power to 10 representation (E-05) 的副本,因为那里给出的答案没有解决手头的问题。这个问题接受的解决方案是使用固定点(例如 20 位),这不是我想要的。定点格式和修剪冗余 0 也不能解决问题,因为固定宽度的最大宽度为 99 个字符。

注意:解决方案必须正确处理自定义数字格式(例如,其他小数点分隔符,具体取决于文化信息)。

编辑:问题实际上只是关于显示上述数字。我知道 float 的工作原理以及可以使用和计算哪些数字。

最佳答案

对于通用¹ 解决方案,您需要保留 339 个位置:

doubleValue.ToString("0."+ new string('#', 339))

非零小数位数最多为 16 位。小数点右边有 15 位。指数最多可以将这 15 位数字向右移动 324 位。 ( See the range and precision. )

适用于 double.Epsilon , double.MinValue , double.MaxValue ,以及介于两者之间的任何东西。

性能将比正则表达式/字符串操作解决方案好得多,因为所有格式化和字符串工作都是由非托管 CLR 代码一次性完成的。此外,代码更容易证明正确。

为了易于使用和更好的性能,将其设为常量:

public static class FormatStrings
{
public const string DoubleFixedPoint = "0.###################################################################################################################################################################################################################################################################################################################################################";
}

¹ 更新:我误说这也是一种无损解决方案。事实上不是,因为 ToString 对除 r 之外的所有格式进行正常显示舍入。 Live example.谢谢,@Loathing!请看Lothing’s answer如果您需要以定点表示法进行往返的能力(即,如果您今天使用 .ToString("r"))。

关于c# - 没有科学记数法的 double 字符串转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1546113/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com