获得一致结果时遇到问题,希望有一些指针尝试自己解决这个问题 碰壁
Excel公式:
=IF(C15=""," ",IF(D15="O"(((ROUNDUP(((C15+0.625)/(6.25-0.5)),0)*6.25))+4.125+0.5),IF(D15="t",C15,"ERROR")))
C15= 100.00
逻辑测试..
D15="O"
第二个逻辑测试中,验证 100.00 是否可以扩展到该数字的预定结果...... if D15="t"
被困,它停留在100.00
....我可以稍后用"if else"替换逻辑测试,仍在学习
<html>
<head>
<title>Excel Formula to JavaScript</title>
</head>
<body>
<script type="text/javascript">
var num1 = 170.00;
var acc1 = (num1 + 0.625)/(6.25-0.50);
var acc2 = Math.round((acc1 * 10) / 10) * 6.25 + (4.125 + 0.50);
document.write(acc2).toFixed(3);
</script>
<div>
<br>
num1= 30.00 result should be 42.125".... incorrect result!
<br>
<br>
num1= 40.00 result should be 54.625".... incorrect result!
<br>
<br>
num1= 57.00 result should be 73.365".... incorrect result!
<br>
<br>
num1= 85.00 result should be 98.375"... result correct
<br>
<br>
when num1= 100.00 result should be 117.125"... result correct
<br>
<br>
seems any input under 77 result will be incorrect
</div>
</body>
</html>
在您的 excel 方程式中,您正在向上舍入。 因此,当C15
30
时,acc1
5.326087
,excel 综述将其带到6
。 Javascript Math.Round(5.326087)
四舍五入到最接近的整体,因此结果为 5
。 这足以抛弃您的最终结果。
您可以将 excel 更改为简单的 Round
而不是 RoundUp
或者您可以将 javascript 更改为 Math.ceil((acc1 * 10) / 10)
不要忘记IF(D15="O",
后面的逗号
如果你想将Excel电子表格转换为Javascript,你可以使用开源库公式.js,由Stoic开发,它实现了大多数Excel函数
它在这里 : http://stoic.com/formula/
否则,我正在开发一种在线软件,该软件可以立即将OpenDocument Calc转换为HTML + JS。有一个演示版本适用于少于 10 个公式的电子表格。
它在这里 : http://appizy.com
祝你的项目好运。
溴,尼古拉斯