java按汉字首字母排序

网上有不少汉字排序可是都有小BUG,这里参考了pinyin4j,修复了BUGjava


1、首先引jar包 web

<!-- 汉字拼音jar包 -->app

 <dependency>
<groupId>com.belerweb</groupId>
<artifactId>pinyin4j</artifactId>
<version>2.5.0</version>
</dependency>
ide


2、下面代码是个工具类,直接使用便可,后续我会添加更多工具,整理了网上了其余人写的工具工具

package com.jusfoun.carray.utils;


import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;


import net.sourceforge.pinyin4j.PinyinHelper;
import net.sourceforge.pinyin4j.format.HanyuPinyinCaseType;
import net.sourceforge.pinyin4j.format.HanyuPinyinOutputFormat;
import net.sourceforge.pinyin4j.format.HanyuPinyinToneType;
import net.sourceforge.pinyin4j.format.exception.BadHanyuPinyinOutputFormatCombination;


import com.jusfoun.carray.vo.out.CompanyResultVo;


/**
 * 汉字拼音工具
 * @author lxy
 *
 */
public class PinyinSortUtil {
  
/**
* 将传入的list,按汉字首字母排序,汉字串会转换成首字母串
* 若是有英文直接是英文,有符号会自动忽略
* @param list 集合list
* @param sortName 须要排序的属性名称
* @return
*/
public static <T> List<T> sortListByFstSpell(List<T> list, String sortName) {
Collections.sort(list, new Comparator<T>() {
@Override
public int compare(T t1, T t2) {
try {
Field field1 = t1.getClass().getDeclaredField(sortName);
field1.setAccessible(true);
Field field2 = t2.getClass().getDeclaredField(sortName);
field2.setAccessible(true);
String s1 = PinyinSortUtil.getFirstSpell((String) field1.get(t1));
String s2 = PinyinSortUtil.getFirstSpell((String) field2.get(t2));
if (s1.compareTo(s2) > 0) {
return 1;
} else {
return -1;
}
} catch (Exception e) {
e.printStackTrace();
return 0;
}
}
});// new Comparator() 根据需求定义排序 ;
return list;
}

/**
* 获取汉字串拼音首字母,英文字符不变  
* @param chinese
* @return
*/
public static String getFirstSpell(String chinese) {
StringBuffer pybf = new StringBuffer();
char[] arr = chinese.toCharArray();
HanyuPinyinOutputFormat defaultFormat = new HanyuPinyinOutputFormat();
defaultFormat.setCaseType(HanyuPinyinCaseType.LOWERCASE);
defaultFormat.setToneType(HanyuPinyinToneType.WITHOUT_TONE);
for (int i = 0; i < arr.length; i++) {
if (arr[i] > 128) {
try {
String[] temp = PinyinHelper.toHanyuPinyinStringArray(
arr[i], defaultFormat);
if (temp != null) {
pybf.append(temp[0].charAt(0));
}
} catch (BadHanyuPinyinOutputFormatCombination e) {
e.printStackTrace();
}
} else {
pybf.append(arr[i]);
}
}
return pybf.toString().replaceAll("\\W", "").trim();
}

/**
* 将汉字转换成拼音
* @param hanzi
* @param separator
* @return
*/
@SuppressWarnings("deprecation")
public static String hanziToPinyin(String hanzi, String separator) {
// 建立汉语拼音处理类
HanyuPinyinOutputFormat defaultFormat = new HanyuPinyinOutputFormat();
// 输出设置,大小写,音标方式
defaultFormat.setCaseType(HanyuPinyinCaseType.LOWERCASE);
defaultFormat.setToneType(HanyuPinyinToneType.WITHOUT_TONE);
String pinyingStr = "";
try {
pinyingStr = PinyinHelper.toHanyuPinyinString(hanzi, defaultFormat, separator);
} catch (BadHanyuPinyinOutputFormatCombination e) {
e.printStackTrace();
}
return pinyingStr;
}

/**
* @param args
* @throws NoSuchFieldException
* @throws SecurityException
*/
public static void main(String[] args) throws Exception {
List<CompanyResultVo> list = new ArrayList<CompanyResultVo>();
CompanyResultVo u = new CompanyResultVo();
   u.setCompanyId(21L);
   u.setCompanyName("中s建设吧");
   list.add(u);  
     
   u=new CompanyResultVo();  
   u.setCompanyName("中国建设吧");  
   u.setCompanyId(18L);  
   list.add(u);  
     
   u=new CompanyResultVo();  
   u.setCompanyName("啊啊啊啊啊");  
   u.setCompanyId(25L);  
   list.add(u);  
     
   u=new CompanyResultVo();  
   u.setCompanyName("啊啊啊啊");  
   u.setCompanyId(89L);  
   list.add(u);  
     
   for(CompanyResultVo user: list) {  
     System.out.println(user.getCompanyName());  
   }
   sortListByFstSpell(list, "companyName");
   System.out.println("排序后!!!!!!!!!");  
   for(CompanyResultVo user: list) {  
     System.out.println(user.getCompanyName());  
   }  
}
}
spa

相关文章
相关标签/搜索