gpt4 book ai didi

javascript - Excel 公式转 JavaScript 函数

转载 作者:行者123 更新时间:2023-11-28 05:45:12 24 4
gpt4 key购买 nike

这是我的Excel公式

fx = ROUNDUP(C17/((1-(1/(1+(C19/12))^(C18*12)))/(C19/12)),0)

excel formula

结果应该是: the result

这是我编写的 JavaScript 函数:

function refreshRenoLoanCalculator() {

var amt = parseInt($('.calc-renoloan .principal-amount').val().replace(/,/g, ''), 10)
console.log(amt); //10 000
var rate = $('.calc-renoloan .loan-rate').val();
console.log(rate); //0.0444
var tenure = $('.calc-renoloan .loan-tenure').val();
console.log(tenure); // 5

var a = rate / 100. / 12.;
console.log(a);
var b = 1. + a;
b = Math.pow(b, (tenure * 12)) - 1.;
console.log(b);
var FC = a / b + a;
FC = FC.toFixed(10);
console.log(FC);
var RP = amt * FC;
console.log(RP);




toolsSetCalculatedValue('.calc-renoloan .calc-result-installment', Math.ceil(RP).toLocaleString().split('.')[0])
$('.calc-renoloan .results-container').slideDown();

}

目前我从 Excel 公式和 javascript 函数得到的结果并不相同。任何帮助将不胜感激。

最佳答案

在 JS 中,等效计算如下:

var C17 = 10000;
var C18 = 5;
var C19 = 4.44;

var interest = C19 / 1200;
var foo = Math.ceil(C17 * interest / (1 - (Math.pow(1/(1 + interest), C18 * 12))));

console.log(foo);

主要区别在于利率的乘法(* 1200 而不是 * 12),因为 Excel 将百分比值存储为 0< 之间的 float 1

如果您希望以与 Excel 相同的方式进行计算,则需要将输入速率转换为:

var C17 = 10000;
var C18 = 5;
var C19 = 0.0444; // Note the difference here

var interest = C19 / 12; // and here
var foo = Math.ceil(C17 * interest / (1 - (Math.pow(1 / (1 + interest), C18 * 12))));

console.log(foo);

关于javascript - Excel 公式转 JavaScript 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38583058/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com