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

统计字符串中不重复字符数量的公式

 要统计字符串中不包括重复字符的数量,即字符串中的字符种类数量,在Excel中可以用下面的一些公式。假如A1单元格中包含字符串“Excel2010”,在B1单元格中输入公式:

    =SUMPRODUCT(--(FIND(MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1),A1)=ROW(INDIRECT("1:"&LEN(A1)))))

    公式返回结果为8,即重复的字符“0”只计算了一次。

    说明:

    1.用MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1)返回包含各字符的数组:{"E";"x";"c";"e";"l";"2";"0";"1";"0"},其中ROW(INDIRECT("1:"&LEN(A1)))返回数组:{1;2;3;4;5;6;7;8;9}

    2.用FIND函数返回各字符在字符串中的起始位置:{1;2;3;4;5;6;7;8;7},然后与上面的数组进行比较:{1;2;3;4;5;6;7;8;7}={1;2;3;4;5;6;7;8;9},返回数组{TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;FALSE},并用双重否定符“--”返回{1;1;1;1;1;1;1;1;0}.

    3.最后用SUMPRODUCT函数返回结果。

    另外,还可以用下面的两个公式:

    =SUM(--(FREQUENCY(FIND(MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1),A1),FIND(MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1),A1))>0))

    或:

    =COUNT(1/FREQUENCY(FIND(MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1),A1),FIND(MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1),A1)))

    如果不区分字符串中英文字母的大小写,将上述公式中的FIND改为SEARCH即可。本例中公式将返回“7”

我的个性签名

快速回复

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