我需要一个公式来匹配下表中A列和B列的日期。我的每个表中都有超过100000个要匹配的结果。
如果两列中都显示了特定日期,则返回“是”语句。如果仅显示在一栏中,则为“否”。
我尝试使用以下公式,但未返回正确的输出:
=IF(COUNTIF($B:$B, $A:$A)=0, "Yes", "No")
正确的结果应该与列C相同。
谢谢。
答案 0 :(得分:3)
请参考公式=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")
图片中的通知我使用“ =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")