脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Golang - go代码实现买房贷款月供计算的方法

go代码实现买房贷款月供计算的方法

2020-05-25 10:23stpeace Golang

今天小编就为大家分享一篇关于go代码实现买房贷款月供计算的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

贷款金额:100元(先以100元为例,来对比下公积金贷款和商业贷款)

公积金贷款年利率: 3.25%

商业贷款的年利率: 4.90%

贷款期限:360个月(30年)

还款方式:等额本息

计算公式:之前推导过, 用等比数列搞起即可

go代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
package main
import (
  "fmt"
  "math"
)
func get_pmt(f_interest_rate float64, term_number int, principal int) float64 {
 compound_rate := math.Pow(1 + f_interest_rate, float64(term_number))
 pmt := float64(principal) * f_interest_rate * compound_rate / (compound_rate - 1)
 return pmt
}
func main(){
 n := 360
 year_month := 12
 p := 100
 r1 := float64(0.0490) / float64(year_month)
 r2 := float64(0.0325) / float64(year_month)
 a := get_pmt(r1, n, p) * float64(n) - float64(p)
 b := get_pmt(r2, n, p) * float64(n) - float64(p)
 fmt.Println(a, b)
}

结果:

91.06161942420968   56.67427486605655

也就是说,如果用商业贷款100元,利息大概是91元。如果用公积金贷款100元,利息大概是57元。

实际上,公积金贷款的最大金额是90万(有要求),其余的缺口需要用商业贷款, 即组合贷款。

下面来具体算算买450万房子和500万房子的月供情况:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
package main
import (
  "fmt"
  "math"
)
func get_pmt(f_interest_rate float64, term_number int, principal int) float64 {
 compound_rate := math.Pow(1 + f_interest_rate, float64(term_number))
 pmt := float64(principal) * f_interest_rate * compound_rate / (compound_rate - 1)
 return pmt
}
func get_month_provide(price int) {
 n := 360
 year_month := 12
 gongjijin_loan_limit := 900000
 shoufu_rate := 0.3
 r1 := float64(0.0490) / float64(year_month)
 r2 := float64(0.0325) / float64(year_month)
 month_provide := get_pmt(r2, n, gongjijin_loan_limit)
 month_provide += get_pmt(r1, n, int(float64(price) * (float64(1) - float64(shoufu_rate)) - float64(gongjijin_loan_limit)) )
 fmt.Println(month_provide)
}
func main(){
 get_month_provide(4500000)
 get_month_provide(5000000)
}

结果:

15858.20808566452
17715.751607844337

如上就是月供金额情况。 跟网上提供的房贷计算器的结果比对了一下,完全一致。

最后,来给一个近似的月供公式, 其中x是买房的房价:

 m = ((0.7 * x - 900000) * 1.9106 + 900000 * 1.5677) / 360
   = 37.15 *  (x/10000) - 860
   = 37.15 * y - 860
   = 37 * y + 0.15y - 860(以深圳房价为例,近似认为0.15y和60相等)
   = 37 * y - 800

所以,买450万的房子和买500万的房子的月供分别为:

  • m(450万) = 37 * 450 - 800 = 15850  (和实际值15858非常接近)
  • m(500万) = 37 * 450 - 800 = 17700  (和实际值17715非常接近)

当然啦,除了月供, 还有首付的30%,还有这费那费, 多得很。

所以, 买房的总支付是:  首付 + 这费那费 + 月供*360

最后,如果不使用组合贷,而纯使用商业贷, 那么月供是多少呢?

容易大致计算出: m = 37 * y  (可以看到,纯商业贷的月供比组合贷的月供贵大约800元,接近1000元)

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。如果你想了解更多相关内容请查看下面相关链接

原文链接:https://blog.csdn.net/stpeace/article/details/89020049

延伸 · 阅读

精彩推荐
  • Golanggolang的httpserver优雅重启方法详解

    golang的httpserver优雅重启方法详解

    这篇文章主要给大家介绍了关于golang的httpserver优雅重启的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,...

    helight2992020-05-14
  • Golanggo语言制作端口扫描器

    go语言制作端口扫描器

    本文给大家分享的是使用go语言编写的TCP端口扫描器,可以选择IP范围,扫描的端口,以及多线程,有需要的小伙伴可以参考下。 ...

    脚本之家3642020-04-25
  • Golanggo日志系统logrus显示文件和行号的操作

    go日志系统logrus显示文件和行号的操作

    这篇文章主要介绍了go日志系统logrus显示文件和行号的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    SmallQinYan12302021-02-02
  • Golanggolang json.Marshal 特殊html字符被转义的解决方法

    golang json.Marshal 特殊html字符被转义的解决方法

    今天小编就为大家分享一篇golang json.Marshal 特殊html字符被转义的解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧 ...

    李浩的life12792020-05-27
  • GolangGolang中Bit数组的实现方式

    Golang中Bit数组的实现方式

    这篇文章主要介绍了Golang中Bit数组的实现方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    天易独尊11682021-06-09
  • Golanggolang 通过ssh代理连接mysql的操作

    golang 通过ssh代理连接mysql的操作

    这篇文章主要介绍了golang 通过ssh代理连接mysql的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    a165861639710342021-03-08
  • GolangGolang通脉之数据类型详情

    Golang通脉之数据类型详情

    这篇文章主要介绍了Golang通脉之数据类型,在编程语言中标识符就是定义的具有某种意义的词,比如变量名、常量名、函数名等等,Go语言中标识符允许由...

    4272021-11-24
  • Golanggolang如何使用struct的tag属性的详细介绍

    golang如何使用struct的tag属性的详细介绍

    这篇文章主要介绍了golang如何使用struct的tag属性的详细介绍,从例子说起,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看...

    Go语言中文网11352020-05-21