Excel公式到Javascript,工作但不一致



获得一致结果时遇到问题,希望有一些指针尝试自己解决这个问题 碰壁

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

祝你的项目好运。

溴,尼古拉斯

最新更新