列表排序对于程序员来说肯定不陌生,Collections.sort()方法可以满足你的各种想法。今天的方案也是基于这个方法,对字母、汉字、数字及其他各种特殊字符进行混合排序。

大家在工作中肯定会遇到对列表排序的情况,下面介绍一种对字母、汉字、数字和其他各种特殊字符进行混合排序的解决方案,希望可以帮到大家。

现在假定一个场景,比如需要读取系统通讯录,然后根据名字进行分组排序并展示,规则如下:字母开头的名字直接按照字母表进行排序;汉字开头的名字按照汉字拼音在字母表中的位置进行排序;数字和其他字符放在列表最后面统一展示。 期望效果如下图:



既然是用Collections.sort()方法来实现,那么最重要的就是实现一个能满足我们要求的Comparator。根据上面的规则,我们可以按以下步骤进行处理:

对名字进行转换

规则如下:

  • 字符为字母,直接转换为大写字母;
  • 字符为中文,转换为对应的拼音,然后再拼音转换为大写;
  • 字符为数字及其他字符,不做处理



这个逻辑很简单:先对名字的每个字符用正则进行匹配,然后根据上面的规则进行处理。汉字转拼音我用的是TinyPinyin这个工具,大家也可以选取其他的工具实现(pinyin4jjpinyin等)。

根据需要对转换后的名字进行处理

根据名字的首字符来判断是否需要对转换后的字符串进行处理:如果首字符是字母或者中文,则不做处理,如果是数字及其他字符,则在第一步得到的字符串前添加一个Unicode值比字母大的任意一个字符。这么做的用处是在对比的时候,能保证数字及其他字符开头的名字始终处于列表的最后(因为Collections.sort()方法是基于对字符的Unicode字符列表的顺序进行比较排序的)。



getLetter()方法是获取首字符对应的字母,数字和其他字符直接返回“#”。



如果不需要对数字及其他字符的排序做处理的话,可以直接省略这一步~

以上两个步骤可以合并成一个方法:



自定义Comparator方法



这里就不用多说啦~

排序

最后调用Collections.sort()方法就可以了


代码实现其实很简单,相信大家都会,主要是方案。附上代码地址,希望能帮到大家,谢谢。