ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > 我的酷贴 > Excel VBA > VBA中多种方法实现数组排序

VBA中多种方法实现数组排序

作者:绿色风 分类: 时间:2022-08-18 浏览:649
楼主
chrisfang
VBA里面没有现成的Sort方法可以使用,VBA里面要对数组进行排序,现有的通常做法:
1,通过单元格赋值以后利用工作表里的Sort方法进行排序,
2,通过SQL实现,也需要调用单元格区域存放数据,
3,直接写循环语句通过算法来实现。

除了上述方法以外,借助一些其他语言工具与VBA相结合,也能利用现成的排序功能来实现数组排序,而不需要借助表格。
例如JavaScript:

JavaScript里面也有Sort方法,可以拿来现成使用,示例代码如下:
  1. Sub 文本升序()
  2. Set js = CreateObject("msscriptcontrol.scriptcontrol")
  3. js.Language = "javascript"
  4. arr = Application.Transpose(Range("A1:A10"))
  5. temp = Join(arr, ",")
  6. js.addcode "function aa(bb){js=bb.split(',');js.sort();return js;}"
  7. sortarr = js.eval("aa('" & temp & "')")
  8. Debug.Print sortarr
  9. End Sub

  10. Sub 文本降序()
  11. Set js = CreateObject("msscriptcontrol.scriptcontrol")
  12. js.Language = "javascript"
  13. arr = Application.Transpose(Range("A1:A10"))
  14. temp = Join(arr, ",")
  15. js.addcode "function aa(bb){js=bb.split(',');js.sort();js.reverse();return js;}"
  16. sortarr = js.eval("aa('" & temp & "')")
  17. Debug.Print sortarr
  18. End Sub

  19. Sub 数值升序()
  20. Set js = CreateObject("msscriptcontrol.scriptcontrol")
  21. js.Language = "javascript"
  22. arr = Application.Transpose(Range("A1:A10"))
  23. temp = Join(arr, ",")
  24. js.addcode "function aa(bb){js=bb.split(',');js.sort(function(a,b){return a-b;});return js;}"
  25. sortarr = js.eval("aa('" & temp & "')")
  26. Debug.Print sortarr
  27. End Sub

  28. Sub 数值降序()
  29. Set js = CreateObject("msscriptcontrol.scriptcontrol")
  30. js.Language = "javascript"
  31. arr = Application.Transpose(Range("A1:A10"))
  32. temp = Join(arr, ",")
  33. js.addcode "function aa(bb){js=bb.split(',');js.sort(function(a,b){return a-b;});js.reverse();return js;}"
  34. sortarr = js.eval("aa('" & temp & "')")
  35. Debug.Print sortarr
  36. End Sub


.NET里面有SortedList类也可以用来实现排序,但需要系统支持Framework

示例代码如下:

  1. Sub Sortlist()
  2. Set objSortedlist = CreateObject("System.Collections.Sortedlist")
  3. For i = 1 To 10
  4. objSortedlist.Add Range("A" & i).Value, Range("A" & i).Value
  5. Next i

  6. For i = 0 To objSortedlist.Count - 1
  7.     Debug.Print objSortedlist.GetKey(i)
  8. Next
  9. End Sub
除了SortedList类,还有ArrayList也可以用

示例代码如下:
  1. Sub Arraylist()
  2. Set objArrayList = CreateObject("System.Collections.ArrayList")
  3. For i = 1 To 10
  4. objArrayList.Add Range("A" & i).Value
  5. Next i

  6. objArrayList.Sort
  7. For i = 0 To objArrayList.Count - 1
  8.     Debug.Print objArrayList(i)
  9. Next
  10. End Sub
2楼
Rongson_Chart
3楼
xyh9999
好好学习
4楼
じ☆潴の︵ゞ
5楼
bluexuemei
调用JAVASCRIPT进行中文排序的话是按照UNICODE码来排序的,而不是按照拼音来排序的
6楼
水星钓鱼
强大,牛

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap