Microsoft Excel是Microsoft為使用Windows和Apple Macintosh操作系統(tǒng)的電腦編寫的一款電子表格軟件。直觀的界面、出色的計算功能和圖表工具,再加上成功的市場營銷,使Excel成為最流行的個人計算機數(shù)據(jù)處理軟件。 對于Excel工作薄中一個包含重復數(shù)值的區(qū)域,要將其中的數(shù)值按出現(xiàn)次數(shù)的多少提取到一列,通常可以用包含MODE函數(shù)的數(shù)組公式。例如數(shù)值區(qū)域為A1:E10,要將其中的數(shù)值提取到G列,如圖。 在G2中輸入: =MODE(IF(COUNTIF($G$1:G1,A$1:E$10)=0,A$1:E$10)) 公式輸入完畢按Ctrl+Shift+Enter結束,然后拖動填充柄向下填充公式,直到出現(xiàn)“#N/A”為止。 受MODE函數(shù)的限制,該公式僅對數(shù)值有效,且不能提取只出現(xiàn)一次的數(shù)值。要將區(qū)域中所有的數(shù)據(jù)按出現(xiàn)次數(shù)提取到一列,可用VBA代碼來實現(xiàn)。如將下圖A1:E10區(qū)域中的文本按出現(xiàn)次數(shù)多少提取到G列: 按Alt+F11,打開VBA編輯器,在代碼窗口中輸入下列代碼并運行,即可G列得到按出現(xiàn)次數(shù)降序排序的文本,在H列得到對應文本的出現(xiàn)次數(shù)。 Sub 按出現(xiàn)次數(shù)排序() Dim d As Object Dim Arr Dim i As Integer, j As Integer Application.ScreenUpdating = False '提取不重復值并計算出現(xiàn)次數(shù) Set d = CreateObject("Scripting.Dictionary") Arr = Range("A1:E10") For i = 1 To UBound(Arr, 1) For j = 1 To UBound(Arr, 2) If Not d.Exists(Arr(i, j)) Then d.Add Arr(i, j), 1 Else d.Item(Arr(i, j)) = d.Item(Arr(i, j)) + 1 End If Next Next '輸出并排序 Range("G2").Resize(d.Count) = Application.Transpose(d.keys) Range("H2").Resize(d.Count) = Application.Transpose(d.items) Range("G2:H2").Resize(d.Count).Sort key1:=Range("H2"), Order1:=xlDescending Set d = Nothing Application.ScreenUpdating = True End Sub 說明:如果文本出現(xiàn)的次數(shù)相同,將按先行后列的順序依次提取 Excel整體界面趨于平面化,顯得清新簡潔。流暢的動畫和平滑的過渡,帶來不同以往的使用體驗。 |
溫馨提示:喜歡本站的話,請收藏一下本站!