王志軍
COUNTIF函數(shù),其實如果巧妙利用,可以在很大程度上完成某些特殊的任務,這里做一簡單介紹。
1.按部門錄入序號
如圖1所示,A列原來是正常的序號編排,現(xiàn)在領導要求在A列按照部門錄入序號,不同部門的序號都從1開始。這里可以在A2單元格輸入公式“=COUNTIF(B$2:B2,B2)”,COUNTIF函數(shù)的統(tǒng)計區(qū)域是B$2:B2,第一個B2表示行的絕對引用,第二個B2表示相對引用。當公式向下復制時,就會依次變?yōu)锽$2:B3、B$2:B4……,這是一個不斷擴展的區(qū)域,從這個動態(tài)區(qū)域中統(tǒng)計B列部門的個數(shù)。
公式輸入之后,向下拖拽或雙擊填充柄,很快就可以得到圖2所示的序號效果。
2.統(tǒng)計不重復的人數(shù)
如圖3所示,領導要求在E列計算不重復的員工人數(shù),如果使用排序功能或篩選功能,不利于數(shù)據(jù)的后續(xù)更新,這里可以使用公式“=SUMPRODUCT(1/COUNTIF(A2:A18,A2:A18))”,這是一個十分常用的統(tǒng)計不重復數(shù)據(jù)個數(shù)的公式,其中包含了一個簡單的數(shù)學邏輯:任意一個數(shù)據(jù)重復出現(xiàn)N次,N個1/N的和值為1。
公式中“COUNTIF(A2:A18,A2:A18)”部分是數(shù)組計算,作用是分別統(tǒng)計A2:A18單元格區(qū)域中每個元素出現(xiàn)的次數(shù),運算過程相當于:
=COUNTIF(A2:A18,A2)
=COUNTIF(A2:A18,A3)
……
=COUNTIF(A2:A18,A18)
返回內存數(shù)組結果為:{2;2;2;2;2;2;2;2;2;2;1;1;1}
再使用1除以返回的內存數(shù)組,得到以下結果:
{0.5;0.5;0.5……;1;1;1}
用1除,即相當于計算COUNTIF函數(shù)所返回內存數(shù)組的倒數(shù)。如果單元格的值在區(qū)域中是唯一值,這一步的結果是1;如果重復出現(xiàn)兩次,這一步的結果就有兩個1/2;如果單元格的值在區(qū)域中重復出現(xiàn)3次,結果就有三個1/3……
即每個元素對應的倒數(shù)合計起來結果仍是1,最后使用SUMPRODUCT函數(shù)進行求和,得出不重復的人員總數(shù),效果如圖4所示。
3.提取不重復的名單
仍然是圖3所示的例子,現(xiàn)在需要提取出A列不重復的員工名單,這里可以使用公式“=INDEX(A:A,1+MATCH(,COUNTIF(G$1:G1,A$2:A$18),))&""”,注意這是一個數(shù)組公式,編輯完成后,需要同時按下“Ctrl+Shift+Enter”組合鍵。公式含義如下:
首先利用COUNTIF函數(shù),在公式所在位置上方的單元格區(qū)域中,分別查找C$2:C$15單元格區(qū)域每個數(shù)據(jù)的個數(shù)。返回一個由0和1構成的數(shù)組,如果A$2:A$18單元格區(qū)域的元素在公式上方出現(xiàn)過,結果就是1;如果沒出現(xiàn),結果就是0。COUNTIF函數(shù)的第一參數(shù)是一個擴展的區(qū)域,公式的提取結果會被重復利用。接下來利用MATCH函數(shù),在COUNTIF函數(shù)返回的數(shù)組中查找第一個0的位置,也就是查找首次出現(xiàn)的數(shù)據(jù)所在的位置,由于數(shù)據(jù)表的標題行占了1行,將這個數(shù)字加1,就是需要提取的不重復數(shù)據(jù)在數(shù)據(jù)表中列的位置。最后利用INDEX函數(shù),以MATCH函數(shù)的計算結果作為索引值,提取C列對應位置上的數(shù)據(jù)。
上述公式的&""表示空文本 ,這是因為INDEX函數(shù)提取到空白單元格的時候,會返回一個無意義的0,加上一個空文本,可以屏蔽這個無意義的0,使單元格里看起來是空白的。
公式執(zhí)行之后,向下拖曳填充柄,直至出現(xiàn)“#N/A”的錯誤信息為止,最終效果如圖5所示。