【财报分析】识别财务造假

Hello 大家好!财报分析系列文章的上一篇我们学习了从资产负债表来分析一家企业的硬实力、债务压力、竞争力、主业专注度以及暴雷的风险。本节,我们继续分析资产负债表,从五个方面识别财务造假。

下面,就和小鱼一起变身柯南,学习掌握识别财务造假的技能吧~

温馨提示:
文章内容源自小鱼最新创建的开源项目https://gitee.com/miali/financial-report-analysis,需要的小伙伴可前往围观。

在开始分析前,导入项目中自定义的 Python 包 analysis 中的相关工具:

from analysis import ANALYSIS_CONFIGS
from analysis.analysis import FinancialAnalysis
from analysis.doc_utils import ReportDocument

其中,ANALYSIS_CONFIGS 定义了财报分析对应的配置文件:

>> ANALYSIS_CONFIGS
['all_analysis.json',
 'asset_quality_analysis.json',
 'asset_indepth_analysis.json',
 'asset_fraud_analysis.json',
 'profit_analysis.json',
 'cash_flow_analysis.json']

本次分析的主题是通过资产负债表进行财务造假分析。因此,实例化分析对象时使用的配置文件为 asset_fraud_analysis.json

analysis = FinancialAnalysis(ANALYSIS_CONFIGS[3])
images, titles, fields = analysis.images, analysis.titles, analysis.fields

至此,准备工作就完成了,接下来我们将变身柯南,识别财务造假。

1. 假销售

伪造假的销售合同来增加利润是最常用的造假手段之一。因为是假装把货卖出去,所以这笔钱实际上是收不到的。

因此,假销售会带来应收账款的虚增。通常应收账款大于 20% 有财务造假的风险,也可以结合年报中披露的应收账款账龄和坏账计提标准是否严格来进一步分析。

下面是应收账款占比分析:

t1 = analysis.init_table('t1')
t1['应收账款+合同资产'] = t1.T[:2].sum()
t1['(应收账款+合同资产)占总资产的比率'] = t1['应收账款+合同资产'] / t1['资产合计(元)']

analysis.format_show_table('t1')

该公司应收账款占比小 20% ,应收账款造假的风险很小。

不过,应收账款占比在逐年上升,很可能行业竞争激烈,货越来越难卖,必须要靠让渡账期来把货卖出去。

analysis.show_plot('t1')

2. 假存款

虚增应收账款,时间一长,钱一直收不回来,难免叫人怀疑。于是,通过 “假存款” 来瞒天过海,伪造假的银行存单,假装钱已经收回开了。因此,会带来货币资金的虚增。

识别假存款,从两个方面入手:

  • 货币资金多利息收入少:利息收入占平均货币资金的比例小于 2%
  • 货币资金多利息支出多:利息费用占净利润的比例大于 10%

也就是,我们要警惕大存大贷的公司,这是自相矛盾的,账上有那么多钱,为什么还要支付那么多利息去贷款呢?很可能货币资金是假的。

1)利息收入

平均货币资金的计算使用期末的货币资金和期初的货币资金计算平均值得出,下面计算最近 5 年的利息收入占平均货币资金的比例:

t2 = analysis.init_table('t2')
t2['平均货币资金'][1:] = (t2['货币资金(元)'][1:].values + t2['货币资金(元)'][:-1].values) / 2
t2['利息收入占平均货币资金的比率'] = t2['利息收入(元)'] / t2['平均货币资金']

analysis.format_show_table('t2')

该公司利息收入占平均货币资金的比例在 3% 左右,大于 2% ,货币资金的真实性比较高。

利息收入基本在 3% 以上,可见公司在货币资金上做了理财规划,利息收入还是不错的。

analysis.show_plot('t2')

2)利息支出

利息支出占净利润的比值大于 10%,并且账上有大量货币资金,即大存大贷的现象,很可能货币资金是假的。

t3 = analysis.init_table('t3')
t3['利息费用占净利润的比率'] = t3['其中:利息费用(元)'] / t3['五、净利润(元)']

analysis.format_show_table('t3')

该公司利息支出不足每年净利润的 1% ,可以忽略不计。

从利息费用和利息支出来看,该公司的货币资金虚增的可能性几乎为 0 。

analysis.show_plot('t3')

3. 假购买

伪造的银行存单,毕竟牵扯到银行,时间一长,东窗事发的可能性也比较大。于是,又动了歪心思,假装把这笔钱花出去。找其他公司签一份假的采购合同,由于合同是假的,根本不会收到货。

因此,“假购买” 会带来预付款项的虚增。此外,长期说不清楚去处的钱,也可能被计入其他应收款。

t4 = analysis.init_table('t4')
t4['预付款项和其他应收款占总资产的比率'] = t4.T[:2].sum() / t4['资产合计(元)']
    
analysis.format_show_table('t4')

该公司预付款项+其他应收款占总资产的比例维持在 1% 的水平,远不足 10% ,因此制造假购买的可能性非常小。

一般情况下,预付款项+其他应收款占总资产的比例大于 10%,则财务造假的可能性比较大。

analysis.show_plot('t4')

4. 假工程

通过 “假存单” “假购买” 来造假,要么牵扯到银行,要么牵扯到其他公司,都不是好办法。于是,喜欢粉饰报表的公司找到了更高级的手段——假工程。假工程时间长、净额大,还不易被察觉。

但是,法网恢恢疏而不漏,凡走过必留下痕迹。正常情况下,在产品非常畅销,供不应求的情况下,我们才会扩大产能,也就是在建工程会增加。但如果一家公司,产品滞销,还在扩大产能,这就很可疑了。

我们要警惕应收账款和存货双高,在建工程也大的公司。

在建工程占比没有固定的比例,可以参照同行业其他公司情况。此外,我们也可以观察几年的年报,对方是否存在在建工程迟迟不转固定资产的问题。

t5 = analysis.init_table('t5')
t5['在建工程占总资产的比率'] = t5['在建工程合计(元)'] / t5['资产合计(元)']

analysis.format_show_table('t5')

该公司在建工程占比在逐年上升,2021 年有小幅回落。在 2020 年在建工程同比增长 28% ,可以到年报中查看是否有具体的说明。

analysis.show_plot('t5')

5. 假存货

存货也是上市公司暴雷的重灾区,一些无良企业为了少算成本,会增加一些存货,达到调节利润的目的。这样的公司会出现毛利率需要,比同行业的其他公司高很多。

识别存货造假有两个方面:

  • 应收账款和存货双高:应收账款占总资产的比率大于 5% ,存货大于 15% 。
  • 毛利率比同行业的公司高很多:正常情况下,毛利率比同行业的公司高,说明产品竞争力强。如果公司很普通,在价格上也不敢卖得比别人贵,成本端对上游也没有优势,那毛利率凭什么高呢?

毛利率是属于利润表的范畴,小鱼会在后续的连载继续更新。下面,我们先来从应收账款占比和存货占比进行分析。

t6 = analysis.init_table('t6')
t6['存货占总资产的比率'] = t6['存货(元)'] / t6['资产合计(元)']

analysis.format_show_table('t6')

该公司最近 5 年存货占比维持在 15% 以内,存货暴雷的风险不大。

绘制存货占比时,将应收账款占比也绘制到一张柱形图。

import pandas as pd
from analysis.utils import plot_show

tmp_df = pd.merge(
    t6['存货占总资产的比率'], 
    t1['(应收账款+合同资产)占总资产的比率'],
    right_index=True,
    left_index=True
)
plot_show(tmp_df, image_title=images['t6'][0], y_label='', y_format='', save_image=True)

该公司应收账款在不断增加,最近 3 年大于 5% ,好在存货也在进一步控制,最近 3 年维持在 14% 以内。总体来看,存货暴雷的风险比较小。

6. 假收购

和存货平分秋色,商誉也是上市公司暴雷的灾区。由于溢价收购,事后发现收购的公司没有想象中那么好,就会带来资产减值损失(商誉减值损失)。严重的,当期净利润直接被减到负数。

如果我们很难辨别收购的公司是否属于优质的资产,或者商誉虚高,却找不到原因时,那就要远离了。

t7 = analysis.init_table('t7')
t7['商誉占总资产的比率'] = t7['商誉(元)'] / t7['资产合计(元)']

analysis.format_show_table('t7')

该公司商誉占比不足 1% ,无商誉暴雷风险。

并且,商誉占比还在逐年下降。如果商誉占比大于 10% ,则需要重点分析。

analysis.show_plot('t7')

以上就是通过资产负债表分析财报造假的所有内容了,最后执行如下代码,可以生成 Word 格式的分析报告。

ReportDocument(analysis).save()

下一期文章,小鱼将和大家一起学习利润的形成过程,解读从营业收入到归母净利润的产生过程。我们下节见啦 ┏(^0^)┛

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容