我正在开发的一个网络应用程序(另一个开发人员写了它)有一个十进制变量,它在小数点后去掉两个零。如果它们包含一个大于 0 的数字或其组合,它不会丢弃尾随的 2 位数字。该值来自文本文件。
示例文本值为:261.00
示例十进制变量 (TotalDue) 是:261
在调试期间,当我将鼠标悬停在“TotalDue”(在下面的示例代码中)上时,该值显示为 261,当我展开调试器时,它显示为“261M”:
decimal TotalDue = Convert.ToDecimal(InputRow.Substring(260, 12));
我尝试将它作为字符串引入(但最初它仍然读作“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
我错过了什么?文本文件数据的来源是否重要?它在 Access 数据库中启动。
更新:今天(2015 年 12 月 1 日)我意识到我从未标记答案,因为我最终废弃了原始代码并在 C#.net 中重写了它。我会标记 Cole Campbell 的答案是正确的,因为他的评论(“以一种能够为它提供有关输入精度的足够数据的方式构建小数。”)是促使我想出我所做的解决方案的原因,即操纵传入的数据。我是用一种方法这样做的——只显示下面重要的部分(AmtDue)。提醒传入数据的格式为“261.00”(例如 AmtDue = 261.00):
string AmtDue = Convert.ToString(AmountDue).Replace(".", "");
string finalstring = ("0000000000" + AmtDue).Substring(AmtDue.Length);