我在某些C#和Excel中遇到了一些非常奇怪的行为......
我自己完成了数学运算,我相信excel可能会给出正确的答案,但我的数学不是很好,所以可能是.Net编译器知道我不知道的事情。
所以我们走了......
以excel表格的形式给出这些数据:
total sale val days irr
2431.65 2424.56 21 5.01
irr(单元格D2)的公式如下:
=ROUND(100 * ((A2 - B2) / B2) * (360 / C2), 2)
当我运行这个C#时,我得到结果4.97 ...
var totalIncludingTax = 2431.65M;
var saleValue = 2424.56M;
var daysRemaining = 21;
var result = Math.Round(100.0m * ((totalIncludingTax - saleValue) / saleValue) * (360 / daysRemaining), 2);
任何人都可以解释我如何强迫C#/ .Net和Excel同意/如何重写这个公式以便两者同意?
答案 0 :(得分:8)
360 / daysRemaining
这将成为C#中的整数除法:360/21 = 17而不是17.14285714,因为它将在Excel中。
将其更改为360.0 /daysRemaining
以使其成为浮点运算(或者已经指出的360米)。