ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 29927|回复: 67

[原创] VBA内存二维数组对象的多key稳定排序算法

  [复制链接]

TA的精华主题

TA的得分主题

发表于 2015-12-4 15:08 | 显示全部楼层 |阅读模式
本帖已被收录到知识树中,索引项:排序
本帖最后由 香川群子 于 2015-12-7 19:38 编辑

一般说,由Excel中的单元格区域数据对象构成的二维数组,可以直接使用工作表排序方法。
不仅速度快,而且无需读入、写出操作。

但是,默认工作表排序方法一次只能使用3个key、所以如果有较多key需要排序时,
可以使用VBA循环代码,一次排1列,逆序循环排序后得到结果。
【注意必须逆序操作,即、权重最小的列第1个排序,而权重最大的列必须最后一个排序。】
这个和我们通常的习惯是相反的,需要注意。

示例代码如下:
  1. Sub test1()
  2.     Dim ar, sr, sr2, i&, j&, tms#

  3.     '假设待排序原始数据是在A1开始的多行、7列区域中
  4.     sr = Array(1, 3, 5, 7)  '需要排序的列的权重顺序
  5.     sr2 = Array(1, 2, 2, 1) '需要排序的列的升降顺序(1为升序、2为降序)
  6.    
  7.     Application.ScreenUpdating = False '禁止刷屏
  8.         For j = UBound(sr) To 0 Step -1 '逆序循环
  9.             [a1].Sort [a1].Offset(, sr(j) - 1), sr2(j) '每次排序1列
  10.         Next
  11.     Application.ScreenUpdating = True
  12.    
  13.    End Sub
复制代码


这样已经很好了。

但是,如果是VBA过程中生成的VBA内存二维数组需要排序,
那么用工作表排序方法就比较麻烦,需要先把二维数组写入工作表,然后排序,然后再读入VBA……

另外,如果是超过65536行甚至几十万、几百万的数据需要排序,
那工作表方法就不能用了,读写数据就需大量时间。

因此,虽然不是很常用,但还是需要一种直接对VBA内存数组进行排序的算法。

VBA排序算法有很多,但基本上都是一维数组排序。
即使简单改写一下能用于二维数组,但对于稳定的多key排序,就无法解决。

因为,稳定排序的冒泡算法速度非常之慢,而速度较快的快速排序是不稳定排序算法,
所以多key排序的结果就会出错。

有鉴于此,我在高手提示下,用简单的VBA代码补充完善了QuickSort算法的稳定排序方法,
因此,已经可以进行二维数组的多key稳定排序了。

代码如附件。
2015/12/7彻底更新附件。
二维数组多key稳定排序 Multi-Key Stable Sort_kagawa.rar (22.25 KB, 下载次数: 1553)



附件更新、加入了必要的注释、以及参数的概略说明。
同时,写了2个test示例代码,分别说明对工作表区域读入二维数组以后的多key稳定排序,
以及直接对VBA内存二维数组进行多key稳定排序的使用方法。

我原创的算法虽然结果是正确的,但速度效率很低。
【因为简单模仿工作表超过3key的多key排序时、需采取倒序排序的方法,因此误入歧途,效率很低】

所以,现在的代码,已经是按照Zamyi大侠的基本算法进行。(仅仅增加了最后的稳定性排序、以及空值移动到最后的算法)

在此深表敬意。(抄袭代码就是致敬!呵呵。)
2015/12/7



评分

11

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-6-19 09:30 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
又涨见识了,原来数组可以排序。

TA的精华主题

TA的得分主题

发表于 2024-6-9 08:54 来自手机 | 显示全部楼层
感谢,代码拿来直接用了。

TA的精华主题

TA的得分主题

发表于 2024-1-15 18:41 | 显示全部楼层
老师,能帮忙写一个多条件排序二维数组的代码吗

TA的精华主题

TA的得分主题

发表于 2022-8-23 08:34 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
谢谢楼主分享。。。

TA的精华主题

TA的得分主题

发表于 2022-8-22 22:41 | 显示全部楼层
老师,如果数据从第3行开始,下面这个多Key排序代码怎样改?谢谢!
Sub test1()
    Dim ar, sr, sr2, i&, j&, tms#

    '假设待排序原始数据是在A1开始的多行、7列区域中
    sr = Array(1, 3, 5, 7)  '需要排序的列的权重顺序
    sr2 = Array(1, 2, 2, 1) '需要排序的列的升降顺序(1为升序、2为降序)
   
    Application.ScreenUpdating = False '禁止刷屏
        For j = UBound(sr) To 0 Step -1 '逆序循环
            [a1].Sort [a1].Offset(, sr(j) - 1), sr2(j) '每次排序1列
        Next
    Application.ScreenUpdating = True
   
   End Sub

TA的精华主题

TA的得分主题

发表于 2022-5-16 20:10 | 显示全部楼层
谢谢楼主分享。。。

TA的精华主题

TA的得分主题

发表于 2022-5-16 18:11 | 显示全部楼层
反馈个问题:汉字排序有问题。
要是能修复就最好了

TA的精华主题

TA的得分主题

发表于 2022-4-16 18:20 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
谢谢老师分享,经常学习你分享的技巧!崇拜!

TA的精华主题

TA的得分主题

发表于 2022-4-8 07:23 来自手机 | 显示全部楼层
标记一下,需要时再学习!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-17 18:45 , Processed in 0.035134 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表