Excel中PMT函数的Java实现

public class PMT {

    /**
     * 
     * 计算月供
     * 
     * @param rate
     *            年利率 年利率除以12就是月利率
     * @param nper
     *            贷款期数,单位月 该项贷款的付款总数。 
     * @param pv
     *            贷款金额,现值,或一系列未来付款的当前值的累积和,也称为本金。 
     * @return
     * 
     */
    public static double calculatePMT(double rate, double nper, double pv) {
        double v = (1 + (rate / 12));
        double t = (-(nper / 12) * 12);
        double result = (pv * (rate / 12)) / (1 - Math.pow(v, t));
        return result;
    }

    public static void main(String[] args) {
        System.out.println((calculatePMT(0.09, 12, 10000) * 12) / 10000 - 1);
        System.out.println((calculatePMT(0.085, 24, 10000) * 24) / 10000 - 1);
        System.out.println((calculatePMT(0.085, 36, 10000) * 36) / 10000 - 1);
    }
}

 扩展阅读:

成长的乐趣,在于分享!
大龄程序员,一路走来,感慨颇多。闲暇时写写字,希望能给同行人一点帮助。
本文版权归作者growithus和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
原文地址:https://www.cnblogs.com/growithus/p/11012169.html