`
阅: 1953 | 回: 0
发表于2015/10/24 15:01:18 楼主 
头像 等级:初学者
积分:0
财富值:0.0
身份:普通用户

从两列中提取相同或不相同数据的数组公式

有时在Excel中需要对两列进行比较,并提取两列中相同或不相同的数据,例如A列和B列分别包含一些人员名单,现在需要找出两列中都存在的姓名(AB有)、A列中存在B列中不存在的姓名(AB无)及A列中不存在B列中存在的姓名(AB有),并分别放置到DEF列中。

假如两列名单分别在A2:A20B2:B15区域中,用下面的两组数组公式即可获取相应的名单,每个公式输入完毕后,需按Ctrl+Shift+Enter结束。

    1.获取A列和B列中相同的数据,在D2中输入数组公式:

    =INDEX($B$2:$B$15,MATCH(1,COUNTIF(D$1:D1,$B$2:$B$15)+IF(COUNTIF($A$2:$A$20,$B$2:$B$15),1,0),0))

    或:

    =INDEX(A:A,SMALL(IF(COUNTIF($B$2:$B$15,$A$2:$A$20),ROW($A$2:$A$20),4^8),ROW(A1)))&""

    2.获取AB无的数据,在E2中输入数组公式:

    =INDEX($A$2:$A$20, MATCH(0, COUNTIF($B$2:$B$15, $A$2:$A$20)+COUNTIF(E$1:E1, $A$2:$A$20), 0))

    或:

    =INDEX(A:A,SMALL(IF(COUNTIF($B$2:$B$15,$A$2:$A$20),4^8,ROW($A$2:$A$20)),ROW(A1)))&""

    3.获取AB有的数据,在F2中输入数组公式:

    =INDEX($B$2:$B$15, MATCH(0, COUNTIF($A$2:$A$20, $B$2:$B$15)+COUNTIF(F$1:F1, $B$2:$B$15), 0))

    或:

    =INDEX(B:B,SMALL(IF(COUNTIF($A$2:$A$20,$B$2:$B$15),4^8,ROW($B$2:$B$15)),ROW(A1)))&""

    上述公式输入完毕后,分别拖动填充柄向下填充,第一组公式直到出现“#N/A”为止,第二组公式直到出现空值为止。

我的个性签名

快速回复

目前不允许游客发表,请 登录 注册 后再发贴。