ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 1218|回复: 0

重复值与唯一值小结

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-1-14 22:18 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 lss001 于 2018-2-19 19:24 编辑

提取单列重复值与唯一值
a,提取唯一值(仅唯一)
辅助列=IF(AND(COUNTIF(A:A,A1)=1,COUNTIF(
$A$1:A1,A1)=COUNTIF(A:A,A1)),A1,"")
非辅助→数组公式<附带排序功能>
=IFERROR(SMALL(IF(FREQUENCY($A$1:$A$10,$A$1:$A$10)=1,$A$1:$A$10),ROW(A1)),"")
个数=SUMPRODUCT((COUNTIF(A:A,A:A)=1)/1)

b,提取唯一值(含重复)
辅助列=IF(COUNTIF($A$1:A1,A1)=1,A1,"")
非辅助<附带排序功能>
=IFERROR(SMALL(IF(FREQUENCY($A$1:$A$10,$A$1:$A$10),$A$1:$A$10),ROW(A1)),"")
非辅助→数组公式→单值<附带排序功能>
=IFERROR(SMALL(IF(MATCH($A$1:$A$10,$A$1:$A$10,0)=ROW($1:$10),$A$1:$A$10,""),ROW(A1)),"")
非辅助→数组公式→多值<附带排序功能>
=IFERROR(SMALL(IF(MATCH($A$1:$A$10,$A$1:$A$10,0)=ROW($1:$10),$A$1:$A$10,""),ROW($a$1:$a$10)),"")
个数=SUMPRODUCT((1/COUNTIF(A:A,A:A))
*************************************************
提示:行应把ROW($a$1:$a$10)
改为COLUMN($A$1:$J$1)

c,提取重复值(单个)
辅助列=IF(AND(COUNTIF(A:A,A1)>1,COUNTIF(
$A$1:A1,A1)=COUNTIF(A:A,A1)),A1,"")
非辅助→数组公式<附带排序功能>
=IFERROR(SMALL(IF(FREQUENCY($A$1:$A$10,$A$1:$A$10)>1,$A$1:$A$10),ROW(A1)),"")
个数=SUMPRODUCT((COUNTIF(A:A,A:A)>1)*(1/COUNTIF(A:A,A:A)))

d,提取重复值(全部)
辅助列=IF(COUNTIF(A:A,A1)>1,A1,"")
非辅助→数组公式<附带排序功能>
=IFERROR(SMALL(IF(COUNTIF($A$1:$A$10,$A$1:$A$10)>1,$A$1:$A$10),ROW(A1)),"")
个数=SUMPRODUCT((COUNTIF(A:A,A:A)>1)/1)

e,提取重复2次的值(单个)
辅助列=IF(AND(COUNTIF(A:A,A1)=2,COUNTIF(
$A$1:A1,A1)=COUNTIF(A:A,A1)),A1,"")
非辅助→数组公式<附带排序功能>
=IFERROR(SMALL(IF(FREQUENCY($A$1:$A$10,$A$1:$A$10)=2,$A$1:$A$10),ROW(A1)),"")

f,提取重复2次的值(全部)
辅助列=IF(COUNTIF(A:A,A1)=2,A1,"")
非辅助→数组公式<附带排序功能>
=IFERROR(SMALL(IF(COUNTIF($A$1:$A$10,$A$1:$A$10)=2,$A$1:$A$10),ROW(A1)),"")
*************************************************
*如果不用排序功能可参考重复文本唯一值公式*

g,重复文本唯一值(含重复)
数组公式→非辅助→单值
=IFERROR(INDEX($A$1:$A$10,SMALL(IF(MATCH($A$1:$A$10,$A$1:$A$10,0)=ROW($A$1:$A$10),ROW($A$1:$A$10),""),ROW(A1))),"")
数组公式→非辅助→多值
=IFERROR(INDEX($A$1:$A$10,SMALL(IF(MATCH($A$1:$A$10,$A$1:$A$10,0)=ROW($A$1:$A$10),ROW($A$1:$A$10),""),ROW($a$1:$a$10))),"")

h,多条件(或数组)唯一值(含重复)
*条件→
IF(($A$1:$A$10=1)*($B$1:$B$10<2),$C1:$C10)
数组公式→非辅助→单值<附带排序功能>
=IFERROR(SMALL(IF(MATCH(IF(($A$1:$A$10=1)*($B$1:$B$10<2),$C1:$C10),IF(($A$1:$A$10=1)*($B$1:$B$10<2),$C1:$C10),0)=ROW($A$1:$A$10),IF(($A$1:$A$10=1)*($B$1:$B$10<2),$C1:$C10),""),ROW(A1)),"")
数组公式→非辅助→多值<附带排序功能>
=IFERROR(SMALL(IF(MATCH(IF(($A$1:$A$10=1)*($B$1:$B$10<2),$C1:$C10),IF(($A$1:$A$10=1)*($B$1:$B$10<2),$C1:$C10),0)=ROW($A$1:$A$10),IF(($A$1:$A$10=1)*($B$1:$B$10<2),$C1:$C10),""),ROW($a$1:$a$10)),"")

提取多列重复值与唯一值
i,提取AB列重复值与唯一值
A列B列都有
辅助列=IF(COUNTIF(B:B,A1)>=1,A1,"")
A列有B列无
辅助列=IF(COUNTIF(B:B,A1)<1,A1,"")
A列无B列有
辅助列=IF(COUNTIF(A:A,B1)<1,B1,"")

j,AB两列合并后取不重复值
=INDEX($A$1:$B$10,SMALL(IF(MATCH($A$1:$A$10&$B$1:$B$10,$A$1:$A$10&$B$1:$B$10,0)=ROW($A$1:$A$10),ROW($A$1:$A$10),4^8),ROW(A1)),COLUMN(A1))

k,提取多列唯一值(含重复)
数组公式:
=INDIRECT(TEXT(MIN(IF((COUNTIF($D$1:D1,$A$2:$C$10)=0)*($A$2:$C$10<>""),ROW($A$2:$C$10)*10^5+COLUMN($A$2:$C$10),2^20*10^5+2^14)),"r0c00000"),)&""

补充内容 (2021-11-6 11:34):
l,提取多列重复2次(唯一值)
=IFERROR(INDIRECT(TEXT(MIN(IF((COUNTIF(A$1:C$9,A$1:C$9)=2)*(COUNTIF(D$1:D1,A$1:C$9)=0),ROW(A$1:C$9)*10^3+COLUMN(A$1:C$9),10^5)),"R0C000"),)&"","")
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2025-1-8 12:00 , Processed in 0.016912 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表