分享

VBA|多关键字排序

 网摘文苑 2017-10-22

1 Range对象的Sort方法

使用Range对象的Sort方法对区域进行排序时,同时最多只能指定3个关键字,当需要超过3个关键字对区域进行排序时,可以通过执行多次Sort方法来实现。需要注意的是在排序时应按照各关键字的倒序顺序,例如,如果需要按A→B→C→D的关键字顺序进行排序,则应按D→C→B→A的顺序执行Sort方法。

如有以下工作表数据:

姓名基础知识教育学心理学教育教学技能教育法规总成绩
同学12722212623119
同学102330473226158
同学112548483634191
同学142347443654204
同学154130325434191
同学162439363333165
同学43329322323140
同学54147244336191
同学63138472526167
同学72127424329162

需要'按'总成绩'、'基础知识'、'心理学'、'教育学'排序:

Sub sortByKeys()

With Me.Range('A1')

.Sort key1:='教育学', order1:=xlDescending, _

key2:='心理学', order2:=xlDescending, Header:=xlYes

.Sort key1:='总成绩', order1:=xlDescending, _

key2:='基础知识', order2:=xlDescending, Header:=xlYes

End With

End Sub

代码运行效果:

姓名基础知识教育学心理学教育教学技能教育法规总成绩
同学142347443654204
同学54147244336191
同学154130325434191
同学112548483634191
同学63138472526167
同学162439363333165
同学72127424329162
同学102330473226158
同学43329322323140
同学12722212623119

上述代码运行后,对应的“排序”对话框(数据→排序):

VBA|多关键字排序

2 Worksheet对象的Sort方法

Sub MoreKeySort()

With ActiveSheet.Sort.SortFields

.Clear

.Add Key:=Range('G1'), SortOn:=xlSortOnValues, Order:=xlDescending

.Add Key:=Range('B1'), SortOn:=xlSortOnValues, Order:=xlAscending

.Add Key:=Range('C1'), SortOn:=xlSortOnValues, Order:=xlDescending

.Add Key:=Range('D1'), SortOn:=xlSortOnValues, Order:=xlDescending

End With

With ActiveSheet.Sort

.SetRange Me.Range('A1').CurrentRegion '指定排序区域

.Header = xlYes '指定排序区域包含标题

.Apply '应用工作表排序

End With

End Sub

代码运行效果:

姓名基础知识教育学心理学教育教学技能教育法规总成绩
同学142347443654204
同学112548483634191
同学54147244336191
同学154130325434191
同学63138472526167
同学162439363333165
同学72127424329162
同学102330473226158
同学43329322323140
同学12722212623119

上述代码运行后,对应的“排序”对话框(数据→排序):

VBA|多关键字排序

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多