重写太深的多个嵌套 IF 的公式

eva*_*nna 17 microsoft-excel-2007 microsoft-excel

我写了一个简单的公式来检查单元格的值。不幸的是,公式对于我的 Excel 2007 版本来说太长了。错误是:

德语:Die angegebene Formel kann nicht eingegeben werden, da sie mehr als 64 Verschachtelungsebenen verwendet。

Chinese: 无法输入指定的公式,因为它使用了比当前文件格式允许的更多的嵌套级别

知道如何使公式更短吗?

“WENN”在德语中是“IF”的意思。

   =WENN(N7>=100000000;0;
    WENN(N7>=99000000;1;
    WENN(N7>=98000000;2;
    WENN(N7>=97000000;3;
    WENN(N7>=96000000;4;
    WENN(N7>=95000000;5;
    WENN(N7>=94000000;6;
    WENN(N7>=93000000;7;
    WENN(N7>=92000000;8;
    WENN(N7>=91000000;9;
    WENN(N7>=90000000;10;
    WENN(N7>=89000000;11;
    WENN(N7>=88000000;12;
    WENN(N7>=87000000;13;
    WENN(N7>=86000000;14;
    WENN(N7>=85000000;15;
    WENN(N7>=84000000;16;
    WENN(N7>=83000000;17;
    WENN(N7>=82000000;18;
    WENN(N7>=81000000;19;
    WENN(N7>=80000000;20;
    WENN(N7>=79000000;21;
    WENN(N7>=78000000;22;
    WENN(N7>=77000000;23;
    WENN(N7>=76000000;24;
    WENN(N7>=75000000;25;
    WENN(N7>=74000000;26;
    WENN(N7>=73000000;27;
    WENN(N7>=72000000;28;
    WENN(N7>=71000000;29;
    WENN(N7>=70000000;30;
    WENN(N7>=69000000;31;
    WENN(N7>=68000000;32;
    WENN(N7>=67000000;33;
    WENN(N7>=66000000;34;
    WENN(N7>=65000000;35;
    WENN(N7>=64000000;36;
    WENN(N7>=63000000;37;
    WENN(N7>=62000000;38;
    WENN(N7>=61000000;39;
    WENN(N7>=60000000;40;
    WENN(N7>=59000000;41;
    WENN(N7>=58000000;42;
    WENN(N7>=57000000;43;
    WENN(N7>=56000000;44;
    WENN(N7>=55000000;45;
    WENN(N7>=54000000;46;
    WENN(N7>=53000000;47;
    WENN(N7>=52000000;48;
    WENN(N7>=51000000;49;
    WENN(N7>=50000000;50;
    WENN(N7>=49000000;51;
    WENN(N7>=48000000;52;
    WENN(N7>=47000000;53;
    WENN(N7>=46000000;54;
    WENN(N7>=45000000;55;
    WENN(N7>=44000000;56;
    WENN(N7>=43000000;57;
    WENN(N7>=42000000;58;
    WENN(N7>=41000000;59;
    WENN(N7>=40000000;60;
    WENN(N7>=39000000;61;
    WENN(N7>=38000000;62;
    WENN(N7>=37000000;63;
    WENN(N7>=36000000;64;
    WENN(N7>=35000000;65;
    WENN(N7>=34000000;66;
    WENN(N7>=33000000;67;
    WENN(N7>=32000000;68;
    WENN(N7>=31000000;69;
    WENN(N7>=30000000;70;
    WENN(N7>=29000000;71;
    WENN(N7>=28000000;72;
    WENN(N7>=27000000;73;
    WENN(N7>=26000000;74;
    WENN(N7>=25000000;75;
    WENN(N7>=24000000;76;
    WENN(N7>=23000000;77;
    WENN(N7>=22000000;78;
    WENN(N7>=21000000;79;
    WENN(N7>=20000000;80;
    WENN(N7>=19000000;81;
    WENN(N7>=18000000;82;
    WENN(N7>=17000000;83;
    WENN(N7>=16000000;84;
    WENN(N7>=15000000;85;
    WENN(N7>=14000000;86;
    WENN(N7>=13000000;87;
    WENN(N7>=12000000;88;
    WENN(N7>=11000000;89;
    WENN(N7>=10000000;90;
    WENN(N7>=9000000;91;
    WENN(N7>=8000000;92;
    WENN(N7>=7000000;93;
    WENN(N7>=6000000;94;
    WENN(N7>=5000000;95;
    WENN(N7>=4000000;96;
    WENN(N7>=3000000;97;
    WENN(N7>=2000000;98;
    WENN(N7>=1000000;99;
    WENN(N7>=500000;100;0)))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))
Run Code Online (Sandbox Code Playgroud)

AFH*_*AFH 65

我认为公式等价于:

=IF(OR(N7>=100000000,N7<500000),0,100-INT(N7/1000000))
Run Code Online (Sandbox Code Playgroud)

现在凯文已经重新格式化了公式,我可以很清楚地看到公式在所有情况下都是正确的。

感谢提问者的评论,我可以说等效的德国公式是:

=WENN(ODER(N7>=100000000;N7<500000);0;100-GANZZAHL(N7/1000000))
Run Code Online (Sandbox Code Playgroud)

  • @pipe,@WhatEvil - 提问者想要减少他的“IF”语句的大小,并且由于他的数据结构,我给出了(给数学家)明显的答案,我完全不同意它在任何意义上都是不正确的或不好的做法。显然,对于线性度较低的函数,需要查找表,但对于这些数据来说,这太过分了,而且很难被认为是最佳的:如果可以避免后者,直接计算总是比查找要好。 (5认同)

tey*_*lyn 21

将所有阈值放入工作表上的一个范围内,并使用具有近似匹配的查找公式。

按查找列的值对数据进行升序排序。如果要使用 VLookup,查找列必须是查找表的第一列。如果您乐于使用索引/匹配组合,则查找列可以位于表中的任何位置。

下面的屏幕截图在单元格 A1 到 B6 中有一个示例查找表。该表按 A 列中的值升序排序。这很重要。如果表格未按升序排序,则以下公式将不起作用。

单元格 E2 中的值与 A 列中的任何值都不完全匹配。Vlookup 公式将查找下一个最小值(即 50),并将返回查找表的第 2 列的结果,用于此近似匹配。请注意,对于近似匹配,VLookup 的第四个参数必须为“TRUE”或 1。

这是公式:

=VLOOKUP(E2,$A$1:$B$6,2,TRUE)
Run Code Online (Sandbox Code Playgroud)

和截图:

在此处输入图片说明

Vlookup 的德语名称是 SVerweis(我认为),您需要在德语 Excel 中用分号替换逗号。我不知道德语 Excel 中的“TRUE”是什么,但是您可以使用 1 表示 TRUE,使用 0 表示 FALSE。

=SVerweis(E2;$A$1:$B$6;2;1)
Run Code Online (Sandbox Code Playgroud)

Hoffentlich klappt 的!!