Excel公式可匹配2列中的多个日期,返回是或否

时间:2018-10-28 18:18:19

标签: excel excel-formula

我需要一个公式来匹配下表中A列和B列的日期。我的每个表中都有超过100000个要匹配的结果。

如果两列中都显示了特定日期,则返回“是”语句。如果仅显示在一栏中,则为“否”。

enter image description here

我尝试使用以下公式,但未返回正确的输出:

=IF(COUNTIF($B:$B, $A:$A)=0, "Yes", "No")

正确的结果应该与列C相同。

谢谢。

3 个答案:

答案 0 :(得分:3)

更快的Excel版本

请参考公式=IF(COUNTIF($A:$A,B2)=0,"No","Yes")

看起来一样,但是速度更快。

=IF(ISERROR(MATCH(B1,$A:$A,0)),"No","Yes")

乍一看,匹配应该更快,因为它不能计数,但是当然原因可能是以下逻辑:
COUNT 搜索整个范围以计算 COUNT ,然后 IF '决定'是否为 0
MATCH 仅搜索范围,直到找到 MATCH ,并且找到 IF “通过 ISERROR 函数决定”如果是TRUE或FALSE。如果匹配项位于范围的底部,则可能会忽略速度差距,但事实并非如此。

重新排列公式

=IF(NOT(ISERROR(MATCH(B1,$A:$A,0))),"Yes","No")

=IF(COUNTIF($A:$A,B2)<>0,"Yes","No")`

不会改变任何事情。 MATCH 仍会搜索直到找到匹配项,并且 COUNT 仍会在整个范围内计数。

因此可以得出结论:

MATCH 是“ Excel ”的使用方式。

答案 1 :(得分:2)

这可以解决问题,命名您要显示的内容。

逻辑是这样的:它计算标准是否存在于A列中。当未找到匹配项(= 0)时,给出“在A列中不存在”。

java.lang.RuntimeException: Unable to start receiver com.example.max.driver_app.AlarmReset: java.lang.NullPointerException at android.app.ActivityThread.handleReceiver(ActivityThread.java:2438) at android.app.ActivityThread.access$1700(ActivityThread.java:143) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1285) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5059) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:818) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:634) at dalvik.system.NativeStart.main(Native Method) Caused by: java.lang.NullPointerException at com.example.max.driver_app.AlarmReset.onReceive(AlarmReset.java:40) at android.app.ActivityThread.handleReceiver(ActivityThread.java:2431)

因此,在您的情况下,当我们应用公式时,它将看起来像这样:

=IF(COUNTIF($A:$A,B2)=0, "Don't exist in Column A","Yes")

enter image description here

图片中的通知我使用“ =IF(COUNTIF($A:$A;B3)=0, "No", "Yes") ”作为分隔符,因为我具有Nordic Excel版本。美国可能会使用“ ;”。

答案 2 :(得分:1)

如果当审计日期列与 date 列匹配且 date 列与审计日期< / em>然后使用

=if((countif(B:B,A2)+countif(A:A,B2))<>0,"Yes","No")

如果在审计日期 date 列匹配时需要结果,请使用:

=if((countif(A:A,B2))<>0,"Yes","No")