将Excel工作薄中区域内的值按出现次数提取到同一列的方法

时间:2022-09-20 08:13:45 

对于Excel工作薄中一个包含重复数值的区域,要将其中的数值按出现次数的多少提取到一列,通常可以用包含MODE函数的数组公式。例如数值区域为A1:E10,要将其中的数值提取到G列,如图。


在G2中输入:

=MODE(IF(COUNTIF($G$1:G1,A$1:E$10)=0,A$1:E$10))

公式输入完毕按Ctrl+Shift+Enter结束,然后拖动填充柄向下填充公式,直到出现“#N/A”为止。

受MODE函数的限制,该公式仅对数值有效,且不能提取只出现一次的数值。要将区域中所有的数据按出现次数提取到一列,可用VBA代码来实现。如将下图A1:E10区域中的文本按出现次数多少提取到G列:


按Alt+F11,打开VBA编辑器,在代码窗口中输入下列代码并运行,即可G列得到按出现次数降序排序的文本,在H列得到对应文本的出现次数。

Sub 按出现次数排序()

Dim d As Object

Dim Arr

Dim i As Integer, j As Integer

Application.ScreenUpdating = False

‘提取不重复值并计算出现次数

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

说明:如果文本出现的次数相同,将按先行后列的顺序依次提取

标签:公式,提取,数值,次数,Excel函数
0
投稿

猜你喜欢

  • 如何在Excel中按单元格颜色进行筛选

    2023-01-09 11:01:48
  • Excel表格如何设置打印区域动画教程

    2022-07-28 11:47:39
  • Win10系统怎么玩Win7游戏?Win10系统玩Win7游戏的方法

    2023-11-26 19:55:49
  • 使用Word 2016的特殊字符键盘快捷键?

    2022-02-26 19:36:05
  • Excel如何设置打印一次单元格内容变一次

    2023-07-22 17:19:10
  • 来看看word排版上经常要用到的几个小技巧,提供你的效率

    2022-10-22 21:39:24
  • word怎么按首字母排序

    2023-12-11 06:40:33
  • 怎么提取Excel单元格中的部分内容?Excel批量提取单元格中部分内容的方法

    2023-01-05 13:31:08
  • Excel表格中既有数字又有文字,怎样提取

    2022-11-14 00:18:22
  • Excel表格如何对内容进行分组?

    2022-06-16 11:57:06
  • 为什么word打不开

    2023-12-03 18:02:16
  • Word2003怎么设置默认打印机

    2022-01-21 14:52:13
  • excel利用VBA生成无重复无空值的数据有效性下拉列表

    2023-05-11 08:28:50
  • Excel 2019查看名称定义步骤图解教程

    2023-03-30 11:10:12
  • excel表格设置筛选的教程

    2022-02-19 04:40:18
  • Word中设置页面为A3打印毕业论文的操作

    2022-11-12 01:11:33
  • win10界面图标变白是什么情况?要怎么恢复?

    2023-08-31 05:38:20
  • word2010中怎么设置段落间距

    2023-12-13 15:35:47
  • Excel快速复制单元格或区域到多个工作表中

    2023-01-08 09:18:31
  • excel表格内标准差怎么计算

    2022-08-23 00:51:49
  • asp之家 电脑教程 m.aspxhome.com