java实现全局/局部解unicode。
前几天使用苹果cms时遇到了unicode,作为面向cv编程的开发者,第一时间就是复制,然而网上的unicode解码代码都是全文解码,对字符串中出现个别unicode的复合语句不友好。
以下代码支持局部解码,也支持全局解码,代码很简单,希望能节约其他面向cv编程的开发者的时间。
/**
* 解局部unicode
* */
private static final String unicodeRegex="\\\\u([0-9a-zA-Z]{4})";
public static String decode(String orgString){
if(TextUtils.isEmpty(orgString) || !orgString.matches(".*"+unicodeRegex+".*"))return orgString;
StringBuilder stringBuilder=new StringBuilder(orgString);
int start;
int end;
int cutDown=0;
String unicode;
Pattern pattern=Pattern.compile(unicodeRegex);
Matcher matcher=pattern.matcher(orgString);
while(matcher.find()){
unicode=matcher.group(1);
char ca=(char)Integer.parseInt(unicode, 16);
start=matcher.start()-cutDown;
end=matcher.end()-cutDown;
stringBuilder.replace(start,end,String.valueOf(ca));
cutDown+=5;//unicode是6个字转一个字
}
return stringBuilder.toString();
}