家具设计师培训班实战课程

跟阿忠学家具设计,月薪8000只是起步

当前位置:
Excel VBA函数_自定义排序

[Excel VBA]自定义排序的三种方法:

诸君好,前前期我们聊了VBA编程和数据的常规排序……VBA常用小代码105:Rang方针的排序操作……
今天我们再聊下自定义排序……
何谓自定义排序,就是按指定的次序对数据源进行排序呗……

今一共共享了三种方法。
第1种方法是系统自带的OrderCustom,优点是代码简练,缺陷是自定义序列有字符长度限制(255个)。
第2种方法是字典+数组设置序列号,再运用了辅助列进行排序。优点是不会损坏单元格的形式和结构,比方单元格中存在的公式、布景等。
第3种方法是只运用字典+数组,借助简单桶排序的技巧,直接对数据在数组中进行排序。优点是效率较高,缺陷是会损坏单元格的结构,比方消除公式等。
(第1种主张掌握,第2种主张了解,第3种……能懂就懂,不懂先放着吧~)

举个例子。
如下图所示,A:C列是数据源。
现需要根据E列所指定的部分先后次序,对数据源进行重新排序,假如部分不在指定序列内,则排放在数据源末尾。

排序结果如下图。

第1种方法代码如下:

Sub FreeSort()
\'eh技术论坛 VBA编程学习与实践 看见星光
Dim n&, rng As Range
Set rng = Range("e2:e" & Cells(Rows.Count, "e").End(xlUp).Row)
Application.AddCustomList (rng)
\'添加一个自定义序列,该参数除了支持单元格方针,也支持数组。
n = Application.CustomListCount
\'自定义序列的数目
Range("a:c").Sort key1:=[a1], order1:=xlAscending, Header:=xlYes, ordercustom:=n + 1
\'运用自定义排序,ordercustom指定运用哪个自定义序列排序。
\'当运用自定义排序时,需要将OrderCustom参数设置为指定的序列在自定义列表中的次序加1
Application.DeleteCustomList n
\'删去新增的自定义序列
End Sub

第2种方法代码如下:

Sub DicSort()
Dim d As Object, r, i&, arr, brr
Set d = CreateObject("ing.dictionary")
r = Range("e2:e" & Cells(Rows.Count, "e").End(xlUp).Row).Value
For i = 1 To UBound(r)
d(r(i, 1)) = i \'方针序列循环装入字典,序号作为item
Next
arr = Range("a2:c" & Cells(Rows.Count, 1).End(xlUp).Row)
\'数据源装入数组arr
ReDim brr(1 To UBound(arr), 1 To 1)
\'声明数组brr装原部分在指定序列中的序号
For i = 1 To UBound(arr)
If d.exists(arr(i, 1)) Then
brr(i, 1) = d(arr(i, 1)) \'将原部分在指定序列中的序列号装入brr
Else
brr(i, 1) = "指定序列不存在"
End If
Next
[d:d].Insert
\'在D列插入一列
[d2].Resize(UBound(brr), 1) = brr
\'新的序列号放入D列
Range("a:d").Sort key1:=[d1], order1:=xlAscending, Header:=xlYes \'D列升序排序
[d:d].Delete \'删去D列
Set d = Nothing
End Sub

第3种方法代码如下:

Sub DicArrSort()
\'eh技术论坛公众号 VBA编程学习与实践 看见星光
Dim d As Object, i&, n&, x&, k&, j&
Dim r, arr, brr, crr
Set d = CreateObject("ing.dictionary")
\'后期绑定字典
r = Range("e2:e" & Cells(Rows.Count, "e").End(xlUp).Row).Value
For i = 1 To UBound(r)
d(r(i, 1)) = i \'方针序列循环装入字典,序号作为item
Next
arr = Range("a2:c" & Cells(Rows.Count, 1).End(xlUp).Row)
\'数据源装入数组
ReDim brr(1 To d.Count + 1, 1 To 1)
\'brr数组用于按序号装数组arr的行号,类似于桶排序的桶
For i = 1 To UBound(arr)
If d.exists(arr(i, 1)) Then
\'假如字典中存在相关部分……
n = d(arr(i, 1))
\'该部分在指定序列中的序号
brr(n, 1) = brr(n, 1) & "," & i
\'将该部分在arr中的行号装入数组brr对应的序号行
Else
brr(UBound(brr), 1) = brr(UBound(brr), 1) & "," & i
\'假如字典中不存在,放入数组brr最后一行
End If
Next
ReDim crr(1 To UBound(arr), 1 To UBound(arr, 2))
\'数组crr放排序后的结果
For i = 1 To UBound(brr)
If brr(i, 1) <> "" Then
\'假如不为空,则有符合指定排序条件的关键词
r = Split(brr(i, 1), ",")
\'将brr该位置储存的行号取出
For x = 1 To UBound(r)
k = k + 1 \'累加行
For j = 1 To UBound(arr, 2)
crr(k, j) = arr(r(x), j)
\'遍历指定行位置数组arr的值移到crr
Next
Next
End If
Next
Range("a2:c" & Cells(Rows.Count, 1).End(xlUp).Row) = crr
\'将数组crr排序后的结果放回单元格区域
Set d = Nothing \'释放字典
Erase arr: Erase brr: Erase crr
\'释放数组
End S

作者:Excel自学网 发布时间:2020.01.04

家具设计课堂是国内做家具设计在线教育的线上培训机构,初入家具设计行业的准家具设计师建议在此技术提升。跟阿忠学家具设计,月薪8000只是起步!您想找一份高薪设计类的研发工作,或许家具设计课堂能帮您实现您的初衷愿景。报名学习QQ:415284424。

系统化培训家具结构设计师从家具设计课堂开始

Excel自学网提供大量优秀的Excel学习资源Excel自学网致力于建设成一个公益型Excel在线自学网站,助您轻松学习Excel