ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > Excel VBA > ListView怎么实现双击列标则自动排序?

ListView怎么实现双击列标则自动排序?

作者:绿色风 分类: 时间:2022-08-17 浏览:114
楼主
zzmxy
Q: ListView中,怎么实现双击列标则可以自动排序?具体要求如下效果:
   
 


A: 使用ListView1_ColumnClick,并设置相关的排序属性即可实现,具体代码如下:
  1. Private Sub ListView1_ColumnClick(ByVal ColumnHeader As MSComctlLib.ColumnHeader)
  2.     With ListView1
  3.         .Sorted = True      'ListView排序属性设置为True,即允许进行排序
  4.         .SortKey = ColumnHeader.Index - 1  '设置排序关键词引用的列
  5.         .SortOrder = IIf(.SortOrder, 0, 1) '设置排序方法
  6.     End With
  7. End Sub
------------------------------------------------------------------
说明:
1. SortKey
    SortKey的语法是:.SortKey [= ]
当integer=0时,使用ListItem的Text属性进行排序;
当integer≥1时,使用SubItem的Text属性进行排序;
由于 ColumnHeader.Index 是从1、2、3 这样的整数进行标记,因此通过ColumnHeader.Index - 1 来实现对ListItem或SubItem的排序。

2. SortOrder
    SortOrder有两种,lvwAscending(升序) 和lvwDescending(降序),其中lvwAscending=1,lvwDescending=0;
我们使用 IIf(.SortOrder, 0, 1),就实现从 升序 → 降序,或降序 → 升序 的切换。

3. 排序方法
   根据第1点,SortKey的说明,我们可以看到,排序是按Text方式进行的,当对数值进行排序时,就并非我们通常的排序结果,
比如:2、11、23、4,当按升序排序,则结果为:11、2、23、4;
因此,如果我们想按数值的大小进行排序,那就要用Format(数值,"00")的方式,将数值整理为02、11、23、04,排序后,就可以得到02、04、11、23的结果。


附件:
ListView排序zz.rar
2楼
水星钓鱼
学习下
3楼
亡者天下
学习一下
4楼
WDZ

免责声明

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

评论列表
sitemap