如何估算内在价值:给初学者的简化DCF,只需要3个数字

如何估算内在价值:给初学者的简化DCF,只需要3个数字

模糊的正确胜过精确的错误。


为什么大多数人不会估值

教科书的DCF公式长这样:V = Σ (FCFt / (1+r)^t) + TV / (1+r)^n。大多数人看到这个就放弃了——“太复杂了,我不是金融专业,我用不了这个。”

巴菲特从来不用这个公式的完整版。他说过:”我从来不用计算器。如果一个投资需要用计算器才能判断值不值,那它大概率不值。”

他的意思是:如果安全边际足够大,你不需要精确到小数点后两位。你只需要知道”大致值多少,当前价格远低于这个大致吗?”如果答案是”显然远低于”——连用计算器都不需要——那这可能是一个好机会。如果你需要精密计算才能”勉强”证明价格低于价值,那安全边际就不够大。

这个观点颠覆了很多人对估值的认知。他们以为估值是一种精确科学——输入正确的数字得到正确的答案。但巴菲特告诉你估值是一种判断艺术——你需要的不是精确的数字而是大致的方向。一个对你来说”显然便宜”的机会比一个”计算出来便宜0.5%”的机会安全得多——因为前者的安全边际足够大,即使你的估算有30%的误差你仍然不亏。


简化DCF:3个数字

你需要的3个数字是:当前自由现金流(在年报的现金流量表中用经营现金流减去资本支出得到)、预期增长率(看过去5年的平均增速然后保守打八折)、你要求的回报率(通常10%到12%,代表你希望获得的最低回报)。

简化版公式——巴菲特称之为”所有者盈余“法:

内在价值约等于当前自由现金流乘以(1加增长率)除以(折现率减增长率)

举个例子:一家公司自由现金流10亿元,预期增长率8%,你要求的回报率10%。内在价值约等于10亿乘以1.08除以0.02,等于540亿。如果这家公司当前市值300亿,安全边际等于(540减300)除以540等于44%——安全边际足够大,可以深入研究。

但这里有一个至关重要的步骤大多数教程不强调:敏感性分析。 你的3个数字都是”猜的”——增长率可能不是8%而是6%或10%,折现率可能不是10%而是12%。你需要用不同的假设重新计算看看估值怎么变化。如果增长率从8%降到6%、折现率从10%升到12%,估值从540亿骤降到177亿——变化了3倍。这个巨大的敏感性告诉你一件事:你的估值精确到个位数毫无意义。 你能知道的只是一个大致的范围。

这就是为什么安全边际如此重要。你的估值一定有误差,安全边际是对这个误差的保险。如果你的估值范围是177亿到540亿,那只有在市值远低于177亿(范围的下限)时你才真正有安全边际。在300亿买入意味着你在赌增长率至少有6%——这可能是合理的赌注也可能不是,取决于你对这家公司的理解深度。


“5分钟估值”的实操步骤

第一步用2分钟找到自由现金流:打开年报现金流量表,经营现金流减去资本支出等于自由现金流。如果公司没有直接列出你自己算。

第二步用1分钟估计增长率:看过去5年的营收或利润增速取平均然后保守一点打八折。如果过去5年平均增长10%你估8%。宁可低估不要高估——因为投资中低估的代价(错过一个机会)远小于高估的代价(买入一个陷阱)。

第三步用1分钟代入公式计算。

第四步用1分钟比较:估值和当前市值之间的安全边际够大吗?如果安全边际超过30%到40%值得深入研究。如果安全边际不到20%通过,去找下一个机会。

5分钟你就知道”这家公司大致值多少、当前价格便宜还是贵”。这个信息比读100篇新闻有用得多——因为新闻告诉你”今天发生了什么”(噪音),而估值告诉你”这家公司值不值这个价”(信号)。

需要特别强调的是:这个5分钟估值不是一个”买入信号”——它是一个”值得深入研究的筛选器”。如果安全边际不够通过,去找下一个机会。如果安全边际够大,这意味着这家公司值得你花几天时间深入研究:读完整的年报、了解行业竞争格局、评估管理层的品格和能力。5分钟估值帮你在几百家公司中快速筛选出值得花时间的少数几家,然后你对这些公司做真正深入的研究。这是一个两阶段的过程:先用简化公式做粗筛(5分钟),再用深度分析做精研(几天到几周)。

很多初学者犯的错误是只做第一步就买入了——“公式算出来安全边际44%,买!”但公式的输入(自由现金流、增长率)可能本身就有问题。也许这家公司今年的自由现金流高是因为推迟了必要的资本支出(借了明年的钱来美化今年的数字),也许过去5年的增长来自一个不可持续的因素。这些问题只有在第二阶段的深度研究中才能发现。公式告诉你”可能便宜”,深度研究告诉你”真的便宜还是看起来便宜”。


这个模型的局限

这个简化版有明显的局限,你必须清楚它们。

增长率是猜的。 估值对增长率极度敏感——差2个百分点估值差2到3倍。应对方法是用保守的增长率,宁可低估不要高估。如果你的估值只有在”乐观增长率”下才显示”便宜”,那它可能并不便宜。

一个实用的检验方法是”悲观测试”:用你认为合理的最悲观的假设重新计算,看在最悲观情况下这家公司值多少。如果在最悲观假设下公司估值仍然高于当前市值,你就有了真正的安全边际——即使一切都往最坏的方向发展你也不亏。如果只有在”合理”或”乐观”假设下才显示便宜,你的安全边际可能是虚假的——一旦现实偏向悲观(在投资中经常如此),你就没有保护了。

假设增长永续。 没有公司永远增长,最终增速会放缓。这个公式只适用于”可预测的、稳定增长”的公司,不适用于初创公司、高速增长公司或周期性公司。如果一家公司过去5年增速波动极大——有些年增长30%有些年下降10%——这个公式对它不适用,因为”预期增长率”这个输入本身就无法确定。

不考虑债务。 两家自由现金流相同的公司一家无债一家重债,它们的价值不同。应对方法是避免重债公司或从估值中扣除净债务。

折现率是主观的。 10%还是12%是你自己的选择,但这个选择大幅影响结果。一般用10%作为基准,如果公司风险更高用12%到15%。

最重要的局限是:所有模型都是错的,有些有用。这个简化DCF不会给你”精确的答案”,它给你”大致的方向”。然后你用安全边际保护自己对抗模型的误差。模型的精确度不重要,安全边际的大小才重要。

还有一个经常被忽视的局限:这个公式只适用于有正的自由现金流的公司。 很多高增长公司(比如早期的亚马逊)自由现金流为负——它们把所有赚到的钱和更多的钱都投入了增长。对这类公司用简化DCF会得出”价值为负数”的荒谬结论。这不是因为这些公司没有价值,而是因为简化模型不适用于这种情况。如果一家公司自由现金流为负,你需要更复杂的估值方法——或者更简单的做法:承认它不在你的能力圈内,把它放到”不了解”的那一堆里去。巴菲特在很长一段时间里就是这样处理亚马逊和谷歌这类公司的——他坦诚地说”我不会估值它们”然后去找他能估值的公司。


巴菲特的”心算”版本

巴菲特实际上用的比上面的公式还要简单。他看一家公司时问自己:”如果我买下整家公司,以当前的盈利能力多少年能回本?”如果答案小于10年、公司有护城河、管理层诚实,他就有兴趣。

这就是市盈率的直觉版本:PE等于10意味着”10年回本”,PE等于20意味着”20年回本”,PE等于5意味着”5年回本”。然后他会问三个追加问题:五年后这家公司还在赚至少和今天一样多的钱吗(护城河)?管理层会把赚的钱合理地分配给股东吗(1美元测试)?我以以合理价格配置安全边际够大吗?

如果前两个问题答案都是”是”且PE小于15,大概率有安全边际。这个”心算”比任何复杂的模型更有用——因为它认知负荷极低,不需要电脑不需要假设,只需要对公司的深入理解。

当然这种”心算”的前提是你必须深入理解这家公司。巴菲特能在30秒内判断一家公司”值不值得看”不是因为他的心算能力比别人强,而是因为他大脑中有70年乘以5小时每天知识复利积累。他的”直觉”不是凭空的直觉——它是几万个小时阅读和思考压缩而成的”快速判断”。你在积累了足够的阅读量之后也会发展出类似的直觉,但在那之前用3个数字的简化DCF公式是一个很好的训练工具。每次用公式估值一家公司时你都在训练自己思考”这家公司的现金流来自哪里、增速由什么决定、什么风险可能让增速下降”——这些思考本身比公式算出的数字更有价值。公式是手段,思考是目的。


一句话总结

估值不需要复杂。模糊的正确胜过精确的错误 3个数字,5分钟,你就知道”大致值多少”。然后用安全边际保护你对抗你的误差。

如果安全边际足够大精确度不重要。如果一家公司你估计值100到150亿,当前市值60亿,你不需要知道”到底值120还是130”。你只需要知道”60亿远低于100到150亿,安全边际足够大,值得深入研究”。


延伸阅读:
- 所有者盈余 — 巴菲特实际使用的”真实利润”指标
- 安全边际 — 为什么估值的精确度不重要而安全边际的大小才重要
- 模糊的正确 — 为什么贝塔值是”精确的错误”


不构成投资建议。估值方法仅供教育参考,实际投资决策应结合完整分析。

如果这篇文章帮你从”估值太难了我不会”变成了”5分钟我也能大致算出来”,欢迎关注公众号「柔和谦卑 履责 求知」。

「柔和谦卑 履责 求知」

常见问题

这篇文章的核心观点适用于中国投资者吗?

适用。本文讨论的原则是跨市场、跨文化的——它们基于人类心理和市场结构的普遍性,而非特定国家的制度安排。具体工具和产品可能不同(比如A股和美股的交易规则),但底层的决策逻辑和心理陷阱在所有市场中都是相似的。

读完这篇文章后,最应该做的一件事是什么?

把你从中获得的一个具体认知写下来,然后检查你当前的投资行为是否与这个认知一致。阅读不改变行为就只是娱乐。真正的学习发生在你把一个概念转化为一条可操作的规则,并且在下一次决策中实际使用它的时候。

延伸参考:Wikipedia

Leave a Comment