Excel交流网
  • 设为首页|收藏本站|手机版
  • Excel-教程-技巧-培训视频

  • 网站首页
  • Excel教程
  • 新闻动态
  • Excel资源
  • 关于我们

Excel教程

Excel操作
Excel函数
Excel图表
Excel VBA
Excel 行业应用

联系方式

Excel中交流网 联系方式

QQ:18449932 


网  址:www.excel-cn.com  

当前位置:网站首页 > Excel教程 > Excel VBA
Excel VBA

Excel VBA实现多关键字排序

对于排序问题,恐怕大家都非常熟悉。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:=xlYes

End With

End Sub


代码运行效果:

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

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

e1.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:=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

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

e2.jpg


点击次数:  更新时间:2017-08-12 15:14:53  【打印此页】  【关闭】
上一条:Excel VBA代码优化技巧介绍  下一条:Excel分级统计汇总数据
本站动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图|网站管理

Excel交流网 版权所有 1999-2020 粤ICP备10043721号

QQ:18449932

免费Excel教程、Excel技巧、Excel培训、Excel函数公式、Excel图表、Excel VBA

Excel教程|Excel技巧|Excel培训|Excel函数公式|Excel图表|VBA

Powered by MetInfo 5.3.12 ©2008-2023  www.metinfo.cn