对于一个包含重复数值的区域,要将其中的数值按出现次数的多少提取到一列,通常可以用包含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列:
Excel定位最后一行的四种方法
文章总结excel定位最后一行的多种方法,使用技巧、快捷键、VBA代码来定位到最后一行。 如果在excel工作表中数据很多,需要快速定位最后一行,有什么可以实现呢? 比如EXCEL可用的表格有65536行,实际有6000多行是填充了数据的,如何快速定位最后一行。 第一,使用技巧完成 按下快捷键:ctrl
按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 vba窗体最小化最大化无边框的设置代码
文章介绍vba窗体最小化最大化无边框的设置代码,并提供excel附件供测试和学习。 我们使用excel中VBA制作的窗体,默认是没有最小化、最大化等等命令的。本文就详细介绍一下vba窗体最小化最大化等按钮添加方法。 用API实现VBA窗体最小化最大化按钮、无边框等。 使用API设置窗体格式,经过简化仅需要两