沈廷靜Python與Javascript與EXCEL IRR函數比較

pmt = [0,0,0,0] #沈廷靜程式設計586設定串列list
pmt[0]=float(input('躉繳金額: '))#float函數轉化為實數(浮點數)
for nper in range(1,4):
    pmt[nper] = float(input('第'+str(nper)+'期回收: '))
def npv(rate):
    y = - pmt[0]
    for j in range(1,4):
        y = y + pmt[j]/(1+rate)**j
    return y
a, b, gap, f = 0.0, 1.0, 9.0, 9.0
maxerror = 0.000001
loopNumber = 1
while (gap > maxerror and abs(f) > maxerror and loopNumber < 100):
    loopNumber+=1
    c = (a+b)/2;
    f = npv(c);
    if ( abs(f) > maxerror and gap > maxerror):
        if ( f>0 ):
            a = c
        else:
           b = c
        gap = b-a;
print('沈廷靜報酬率: ', c)
print('沈廷靜淨現值: ', f)
print('沈廷靜迴圈次數: ', loopNumber)

學習Python程式設計讓我理解程式邏輯的運作,語法簡潔易懂,讓我對編程充滿興趣,並提升了解決問題的能力。

留言

  1. 有練習製作一個影片,很優秀!https://pagestjing.blogspot.com/2025/06/pmt-0000-586list-pmt0floatinput-float.html

    回覆刪除

張貼留言

這個網誌中的熱門文章

沈廷靜python自訂函數excel PV和繪圖