人气 4879

[Excel技巧] Excel VBA实现多关键字排序 [复制链接]

swimsuit 2017-8-12 15:14:53
对于排序问题,恐怕大家都非常熟悉。Excel系统也自带了好多排序的功能。下面的示例使用Excel VBA来排序,主要用Sort方法。
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:=xlYesEnd WithEnd Sub
代码运行效果:
姓名基础知识教育学心理学教育教学技能教育法规总成绩
同学142347443654204
同学54147244336191
同学154130325434191
同学112548483634191
同学63138472526167
同学162439363333165
同学72127424329162
同学102330473226158
同学43329322323140
同学12722212623119
上述代码运行后,对应的“排序”对话框(数据→排序):

1502522295348815.jpg

1502522295348815.jpg

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:=xlDescendingEnd WithWith ActiveSheet.Sort.SetRange Me.Range("A1").CurrentRegion  '指定排序区域.Header = xlYes  '指定排序区域包含标题.Apply  '应用工作表排序End WithEnd Sub
代码运行效果:
姓名基础知识教育学心理学教育教学技能教育法规总成绩
同学142347443654204
同学112548483634191
同学54147244336191
同学154130325434191
同学63138472526167
同学162439363333165
同学72127424329162
同学102330473226158
同学43329322323140
同学12722212623119
上述代码运行后,对应的“排序”对话框(数据→排序):

1502522275124641.jpg

1502522275124641.jpg
您需要登录后才可以回帖 登录 | 立即注册

QQ|手机版|精益人 ( 沪ICP备19004111号-1 )|网站地图

GMT+8, 2024-12-23 04:49 , Processed in 0.241619 second(s), 22 queries .

Powered by Lean.ren X3.5 Licensed  © 2001-2030 LEAN.REN