当需要显示时,十进制数据类型正在剥离尾随零

Dor*_*een 10 c# string types decimal

我正在研究的一个Web应用程序(另一个开发者编写它)有一个十进制变量,它在小数点后减去两个零.如果它们包含数字> 0或其组合,则不会丢弃尾随的2位数字.该值来自文本文件.

示例文本值为: 261.00

十进制变量示例(TotalDue)是: 261

在调试期间,当我将鼠标悬停在"TotalDue"上时(在下面的示例代码中),该值显示为261,当我展开调试器时,它显示为"261M":

decimal TotalDue = Convert.ToDecimal(InputRow.Substring(260, 12));
Run Code Online (Sandbox Code Playgroud)

我已经尝试将其作为一个字符串(但最初它仍然显示为"261"而不是261.00),然后以各种方式将其转换如下.没有什么工作!

string TotalDue = InputRow.Substring(260, 12);

strTotalDue = String.Format("{0:F2}", TotalDue);

strTotalDue = String.Format("{0:N2}", TotalDue);

strTotalDue = String.Format(TotalDue, "0.00");

strTotalDue = TotalDue.ToString("G29");  

strTotalDue = String.Format("{0:0.00}", TotalDue);

strTotalDue = TotalDue.ToString("N2");//used this one with decimal data type
Run Code Online (Sandbox Code Playgroud)

我错过了什么?文本文件数据源自何处?它始于Access数据库.

更新:今天(12/1/15)我意识到我从未标记过答案,因为我最终废弃原始代码并用C#.net重写它.我将Cole Campbell的答案标记为正确,因为他的评论("以一种为其提供关于输入精度的足够数据的方式构造十进制.")促使我提出我操作的解决方案.传入的数据.我在一个方法中这样做 - 只显示下面重要的部分(AmtDue).提醒传入的数据格式为"261.00"(例如AmtDue = 261.00):

string AmtDue = Convert.ToString(AmountDue).Replace(".", "");           
string finalstring =  ("0000000000" + AmtDue).Substring(AmtDue.Length);
Run Code Online (Sandbox Code Playgroud)

Tim*_*ter 14

如果你想要两个小数位,你可以使用正确的ToString:

string formatted = TotalDue.ToString("0.00");
Run Code Online (Sandbox Code Playgroud)

>演示<

标准数字格式字符串

(顺便说一句,ToString("D2")不起作用)


Col*_*ell 14

您的第一个示例是丢弃零的原因可能与您创建Decimal实例的方式有关. Decimal包含影响ToString()工作方式的缩放因子,并根据Decimal构造方式不同地设置此缩放因子.

这段代码:

var d1 = Decimal.Parse("261.00");
var d2 = new Decimal(261.00);
var d3 = 261.00m;
Console.WriteLine(d1);
Console.WriteLine(d2);
Console.WriteLine(d3);
Run Code Online (Sandbox Code Playgroud)

产生以下结果:

261.00
261
261.00
Run Code Online (Sandbox Code Playgroud)

如果要保留尾随零,请Decimal以一种为其提供有关输入精度的足够数据的方式构造它.

请记住,正如其他答案所述,调试器提供的字符串不一定与生成的字符串相同ToString().


Bob*_*son 5

您在调试器中看到的数字与它实际显示的方式没有任何关系。 261M是正确的 - 它的值是“261”,以十进制(“M”=“Money”=十进制)格式存储。

请尝试此处的数字格式代码。“F2”就是你想要的。