Excel VBA冒泡排序代码大揭秘!
创作时间:
作者:
@小白创作中心
Excel VBA冒泡排序代码大揭秘!
引用
CSDN
等
11
来源
1.
https://blog.csdn.net/VBAxiaoxueshen/article/details/123495435
2.
https://zhuanlan.zhihu.com/p/587751958
3.
https://blog.csdn.net/aaron19822007/article/details/124647770
4.
https://blog.csdn.net/Eternal_Whispers/article/details/127408919
5.
https://blog.csdn.net/hhhhh_51/article/details/124333750
6.
https://blog.csdn.net/qq_42678477/article/details/107306415
7.
https://blog.csdn.net/adghjkghjkl/article/details/114921391
8.
https://club.excelhome.net/forum.php?mod=viewthread&tid=1212171&extra=&mobile=2
9.
https://club.excelhome.net/thread-1681191-1-1.html
10.
https://club.excelhome.net/thread-1052790-1-1.html
11.
https://www.cnblogs.com/Stefan-Gao/p/14305321.html
在Excel VBA编程中,掌握高效的排序算法是提升工作效率的关键。本文将深入解析如何编写VBA冒泡排序代码,从一维数组到二维数组,逐步介绍升序和降序排列的方法。通过实际案例演示,帮助你轻松掌握这一实用技能,让你的工作更加高效便捷。
01
冒泡排序原理简介
冒泡排序是一种简单的排序算法,通过重复遍历待排序的列表,比较相邻元素,如果顺序错误就交换他们,直到没有需要交换的元素为止。时间复杂度是O(n²),适用于小数据集。
02
一维数组排序实现
基本代码实现
Sub BubbleSort()
Dim arr As Variant
Dim i As Long, j As Long
Dim temp As Variant
' 示例数组(可根据需要修改)
arr = Array(5, 3, 8, 6, 2, 7, 1, 4)
' 外层循环控制遍历次数
For i = LBound(arr) To UBound(arr) - 1
' 内层循环进行相邻元素比较
For j = LBound(arr) To UBound(arr) - i - 1
If arr(j) > arr(j + 1) Then
' 交换元素
temp = arr(j)
arr(j) = arr(j + 1)
arr(j + 1) = temp
End If
Next j
Next i
' 输出排序结果到调试窗口
For i = LBound(arr) To UBound(arr)
Debug.Print arr(i)
Next i
End Sub
升序和降序实现
要实现降序排序,只需修改比较条件:
If arr(j) < arr(j + 1) Then
应用到工作表数据
将工作表数据读取到数组中,排序后再输出:
Sub SortWorksheetData()
Dim arr As Variant
Dim lastRow As Long
' 获取数据范围
lastRow = Cells(Rows.Count, "A").End(xlUp).Row
arr = Range("A1:A" & lastRow).Value
' 调用冒泡排序函数
BubbleSort arr
' 将排序后的数据输出到B列
Range("B1:B" & lastRow) = WorksheetFunction.Transpose(arr)
End Sub
03
二维数组排序实现
二维数组的排序需要使用类模块来实现。以下是一个简单的类模块实现:
' 类模块名称:clsBubbleSort
Option Explicit
Private myArray() As Variant
Private mySortColumn As Long
Private myIsAscending As Boolean
Public Property Let Array(arr() As Variant)
myArray = arr
End Property
Public Property Get Array() As Variant
Array = myArray
End Property
Public Property Let SortColumn(col As Long)
mySortColumn = col
End Property
Public Property Get SortColumn() As Long
SortColumn = mySortColumn
End Property
Public Property Let IsAscending(asc As Boolean)
myIsAscending = asc
End Property
Public Property Get IsAscending() As Boolean
IsAscending = myIsAscending
End Property
Public Sub Sort()
Dim i As Long, j As Long
Dim temp As Variant
For i = LBound(myArray, 1) To UBound(myArray, 1) - 1
For j = LBound(myArray, 1) To UBound(myArray, 1) - i - 1
If (myIsAscending And myArray(j, mySortColumn) > myArray(j + 1, mySortColumn)) Or _
(Not myIsAscending And myArray(j, mySortColumn) < myArray(j + 1, mySortColumn)) Then
' 交换行
temp = myArray(j, mySortColumn)
myArray(j, mySortColumn) = myArray(j + 1, mySortColumn)
myArray(j + 1, mySortColumn) = temp
End If
Next j
Next i
End Sub
使用类模块进行排序:
Sub Sort2DArray()
Dim arr() As Variant
Dim sorter As clsBubbleSort
Dim lastRow As Long
' 获取数据范围
lastRow = Cells(Rows.Count, "A").End(xlUp).Row
arr = Range("A1:B" & lastRow).Value
' 创建类实例并设置属性
Set sorter = New clsBubbleSort
sorter.Array = arr
sorter.SortColumn = 1 ' 按第一列排序
sorter.IsAscending = True ' 升序排序
' 执行排序
sorter.Sort
' 输出排序后的数据
Range("D1:E" & lastRow) = sorter.Array
End Sub
04
错误处理机制
在实际应用中,需要考虑以下错误情况:
- 数组为空或数据类型不匹配
- 工作表数据范围错误
- 内存溢出
错误处理示例:
Sub SafeBubbleSort()
Dim arr As Variant
Dim i As Long, j As Long
Dim temp As Variant
On Error GoTo ErrorHandler
' 示例数组(可根据需要修改)
arr = Array(5, 3, 8, 6, 2, 7, 1, 4)
' 外层循环控制遍历次数
For i = LBound(arr) To UBound(arr) - 1
' 内层循环进行相邻元素比较
For j = LBound(arr) To UBound(arr) - i - 1
If arr(j) > arr(j + 1) Then
' 交换元素
temp = arr(j)
arr(j) = arr(j + 1)
arr(j + 1) = temp
End If
Next j
Next i
' 输出排序结果到调试窗口
For i = LBound(arr) To UBound(arr)
Debug.Print arr(i)
Next i
Exit Sub
ErrorHandler:
MsgBox "发生错误:" & Err.Description, vbCritical
End Sub
05
总结和注意事项
冒泡排序虽然简单易懂,但效率较低(时间复杂度O(n²)),只适合处理小规模数据。在实际工作中,如果数据量较大,建议使用更高效的排序算法,如快速排序或Excel自带的排序功能。
在使用VBA排序时,需要注意以下几点:
- 数组的索引边界(LBound和UBound)
- 数据类型的一致性
- 错误处理机制的完善
- 大数据量时的性能问题
通过本文的讲解,相信你已经掌握了VBA冒泡排序的基本原理和实现方法。在实际工作中,可以根据具体需求选择合适的排序算法,提高工作效率。
热门推荐
“白月光”是什么意思,“朱砂痣”又怎么理解?
沙漠中的动物有哪些适应性?探秘动物在极端环境中的生存策略
健身党的蜂蜜水饮用秘籍
李芷薇教你正确喝蜂蜜水减肥
蜂蜜水助消化,你喝对了吗?
破伤风感染用什么抗生素
关注破伤风,健康共行动!济南市第三人民医院举办专题科普宣传活动
小伤口别不当回事!出现这些症状及时就医!可能是破伤风!
控制饮食,降低食物升糖指数,糖尿病管理助手来帮忙!
心学问青少年教育,激发孩子的探索精神:对世界保持无限好奇
韩启德、潘建伟等多位院士领衔,《十万个为什么》第七版启动
《无所畏惧2》:当官场野心遇上职场理想,一段婚姻的悲剧性终结
圣斗士星矢阿鲁迪巴技能览 金牛座圣斗士图鉴
打造健康未来,促进儿童全面发展的关键策略
各国护照版式大不同,OCR技术如何应对?
视觉训练原来有这么多神奇的作用
弱视的训练方法有哪些?一篇解读:原理/训练项目/适宜人群/收费标准!
春节申遗成功后的首个新年:传统习俗里的新气象
智慧公园:高科技图纸设计的新潮流
深度解析:恒星的颜色!天上星星真实颜色大揭秘
孕期焦虑?这些心理支持技巧帮你顺利分娩!
科学分娩全流程指南:从临产准备到宝宝出生
科学分娩前后,孕妇如何吃出好体质?
机器学习预测中国黄金市场新趋势
徐碧韩医师详解:蜂蜜水的最佳饮用时间
血脂高喝什么茶? 推荐调理“四高”中药茶饮
成都蓉城能否问鼎2025年中超?
2025中超五强争霸:申花领跑,海港蓉城紧追不舍
中超新星闪耀:战术革新中的青春力量
创新升级的运河大集:让千年古镇焕发新活力