ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > Excel VBA > 如何利用VBA代码反转列表框的数据?

如何利用VBA代码反转列表框的数据?

作者:绿色风 分类: 时间:2022-08-17 浏览:118
楼主
wise
Q:如何利用VBA代码反转列表框的数据?
A:ALT+F11→插入相关窗体及以下代码

  1. Option Explicit
  2. Private Sub UserForm_Initialize()
  3.     Dim cell As Range
  4.     '获取工作表数据
  5.     With ListBox_Items
  6.         For Each cell In Range(Cells(2, 1), Cells(ActiveSheet.UsedRange.Rows.Count, 1))
  7.             .AddItem cell.Value
  8.             .List(.ListCount - 1, 1) = cell.Offset(0, 1).Value
  9.             .List(.ListCount - 1, 2) = cell.Offset(0, 2).Value
  10.         Next cell
  11.     End With
  12. End Sub
  13. Private Sub CmdBtn_Exit_Click()
  14.     Unload Me
  15. End Sub
  16. Private Sub CheckBox_Descend_Change()
  17.     Call lBoxReverseOrder(ListBox_Items)
  18.     '调用lBoxReverseOrder模块
  19. End Sub
  20. Public Sub lBoxReverseOrder(myLbox As MSForms.ListBox)
  21.     Dim i As Long
  22.     Dim j As Long
  23.     Dim aryContents() As String
  24.     Dim iListCnt
  25.     Dim iColCount
  26.     With myLbox
  27.         '列表的数目
  28.         iListCnt = .ListCount - 1
  29.         '获取列数
  30.         iColCount = .ColumnCount
  31.         '列表数少于2的时候退出
  32.         If .ListCount < 2 Then
  33.             Exit Sub
  34.         End If
  35.         '准备合适的数组支持列表内容
  36.         ReDim aryContents(iListCnt, iColCount)
  37.         '
  38.         For i = 0 To iColCount - 1
  39.             For j = 0 To iListCnt
  40.                 aryContents(j, i) = .List(iListCnt - j, i)
  41.             Next j
  42.         Next i
  43.         .List = aryContents
  44.     End With
  45. End Sub



ReverseLboxOrder.rar
2楼
亡者天下
过来学习一下

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap