2019-07-07

VBA里面没有现成的Sort方法可以使用,VBA里面要对数组进行排序,现有的通常做法: 

1,通过单元格赋值以后利用工作表里的Sort方法进行排序, 

2,通过SQL实现,也需要调用单元格区域存放数据, 

3,直接写循环语句通过算法来实现。

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

例如JavaScript:

JavaScript里面也有Sort方法,可以拿来现成使用,示例代码如下: 

Sub文本升序()

Set js = CreateObject(“msscriptcontrol.scriptcontrol”) 

js.Language = “javascript” 

arr = Application.Transpose(Range(“A1:A10”)) 

temp = Join(arr, “,”) 

js.addcode “function aa(bb){js=bb.split(‘,’);js.sort();return js;}” 

sortarr = js.eval(“aa(‘” & temp & “’)”) 

Debug.Print sortarr 

End Sub 

复制代码 

Sub文本降序()

Set js = CreateObject(“msscriptcontrol.scriptcontrol”) 

js.Language = “javascript” 

arr = Application.Transpose(Range(“A1:A10”)) 

temp = Join(arr, “,”) 

js.addcode “function aa(bb){js=bb.split(‘,’);js.sort();js.reverse();return js;}” 

sortarr = js.eval(“aa(‘” & temp & “’)”) 

Debug.Print sortarr 

End Sub 

复制代码 

Sub数值升序()

Set js = CreateObject(“msscriptcontrol.scriptcontrol”) 

js.Language = “javascript” 

arr = Application.Transpose(Range(“A1:A10”)) 

temp = Join(arr, “,”) 

js.addcode “function aa(bb){js=bb.split(‘,’);js.sort(function(a,b){return a-b;});return js;}” 

sortarr = js.eval(“aa(‘” & temp & “’)”) 

Debug.Print sortarr 

End Sub 

复制代码 

Sub数值降序()

Set js = CreateObject(“msscriptcontrol.scriptcontrol”) 

js.Language = “javascript” 

arr = Application.Transpose(Range(“A1:A10”)) 

temp = Join(arr, “,”) 

js.addcode “function aa(bb){js=bb.split(‘,’);js.sort(function(a,b){return a-b;});js.reverse();return js;}” 

sortarr = js.eval(“aa(‘” & temp & “’)”) 

Debug.Print sortarr 

End Sub 

复制代码

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

示例代码如下: 

Sub Sortlist() 

Set objSortedlist = CreateObject(“System.Collections.Sortedlist”) 

For i = 1 To 10 

objSortedlist.Add Range(“A” & i).Value, Range(“A” & i).Value 

Next i 

For i = 0 To objSortedlist.Count - 1 

Debug.Print objSortedlist.GetKey(i) 

Next 

End Sub 

复制代码

除了SortedList类,还有ArrayList也可以用

示例代码如下:

Sub Arraylist() 

Set objArrayList = CreateObject(“System.Collections.ArrayList”) 

For i = 1 To 10 

objArrayList.Add Range(“A” & i).Value 

Next i 

objArrayList.Sort 

For i = 0 To objArrayList.Count - 1 

Debug.Print objArrayList(i) 

Next 

End Sub 

复制代码

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 写在前面的话 代码中的# > 表示的是输出结果 输入 使用input()函数 用法 注意input函数输出的均是字...
    FlyingLittlePG阅读 8,186评论 0 9
  • DAY 05 1、 public classArrayDemo { public static void mai...
    周书达阅读 4,086评论 0 0
  • 这段时间颇有点邯郸学步的感觉,由于把大量的时间和精力投入到python中,之前学的vba到想用的时候,居然忘了。 ...
    猛犸象和剑齿虎阅读 13,783评论 0 8
  • 前端开发面试题 面试题目: 根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增加。 题目类型: 理论知...
    怡宝丶阅读 7,408评论 0 7
  • 我是一个嗜睡的人,平日里有机会便想睡个懒觉。平常早起的时候也是急匆匆地走在路上,从未留意过周遭。 所以,每一次悠闲...
    咚2咯咯阅读 1,612评论 0 1

友情链接更多精彩内容