首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >分组经常性CF的Excel净现值

分组经常性CF的Excel净现值
EN

Stack Overflow用户
提问于 2016-07-14 02:46:51
回答 2查看 732关注 0票数 2

下面是60个时期的现金流量表。

有一组经常性的现金流。在excel中有没有一种简单的方法来计算所有60个期间(每月现金流量)的NPV,而不必创建一个60行的表并使用NPV公式?

因此,60行项目的公式如下所示:

=NPV(PERIODIC RATE, VALUES OF CF 1 - 60) + CF0

但是,如果你知道excel中有经常性的现金流,而不必枚举所有60行,你能简化它吗?

提前谢谢。

EN

回答 2

Stack Overflow用户

发布于 2016-07-14 03:38:25

没有内置的函数可以做到这一点,但我们可以构建自己的函数。这是一个UDF(用户定义函数):

代码语言:javascript
复制
Function myNPV(rate As Double, vl As Range, times As Range)
If vl.Cells.Count <> times.Cells.Count Then Exit Function
Dim vlArr() As Variant
Dim timesArr() As Variant
Dim ovlArr() As Double
Dim i&, j&, t&, cnt&

vlArr = vl.Value
timesArr = times.Value
For i = LBound(vlArr, 1) To UBound(vlArr, 1)
    If vlArr(i, 1) <> "" Then
        t = t + timesArr(i, 1)
    End If
Next i
cnt = 1
ReDim ovlArr(1 To t)
For i = LBound(vlArr, 1) To UBound(vlArr, 1)
    If vlArr(i, 1) <> "" Then
        For j = 1 To timesArr(i, 1)
            ovlArr(cnt) = vlArr(i, 1)
            cnt = cnt + 1
        Next j
    End If
Next i

myNPV = Application.WorksheetFunction.NPV(rate, ovlArr)

End Function

在工作簿中按Alt-F11组合键。这将打开VBE。

转到“插入”,然后插入模块。这将打开一个新模块。复制并粘贴上面的代码。

你可以像任何其他公式一样叫它:

代码语言:javascript
复制
=myNPV(C20/C19,B3:B17,C3:C17)+B2

这有三个标准: rate per,金额范围和相应的次数。

票数 1
EN

Stack Overflow用户

发布于 2016-07-14 14:57:17

您可以使用年金公式

=1/($B$7/12)*(1-1/(1+$B$7/12)^C1)*B1*1/(1+$B$7/12)^(SUM($C$1:C1)-12)中使用=1/($B$7/12)*(1-1/(1+$B$7/12)^C1)*B1*1/(1+$B$7/12)^(SUM($C$1:C1)-12)并向下复制

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38359503

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档