返回首页
当前位置: 主页 > Excel教程 > Excel VBA教程 >

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

时间:2013-12-09 01:37来源:Office教程学习网 www.office68.com编辑:麦田守望者

VBA里面没有现成的Sort方法可以使用,在ExcelVBA里面要对数组进行排序,现有的通常做法:
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_r("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_r("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_r("aa('" & temp & "')")
Debug.Print sortarr
End Sub

 

 

------分隔线----------------------------
标签(Tag):excel excel2007 excel2010 excel2013 excel2003 excel技巧 excel教程 excel实例教程
------分隔线----------------------------
推荐内容
猜你感兴趣