在页面中显示某字段时,字段值过长会导致页面样式错乱,这时候我们需要对值进行截取,当截取值时会碰到以下问题:
1、如果按字符截取会导致中英文显示的长度不一
2、如果按字节截取可能会导致最后一个中文截成两部分
以下代码是在网上获取并经过改造而成,能够很好的解决上面两个问题
/**
* 根据指定字节数截取字符串,当指定处为中文第一个字节时少截取一个字符,当长度大于指定截取长度时,截取后在字符串末尾追加指定字符串<br/>
* 这里添加了字符串的编码,因为页面的编码不同,字符串所占字节也不同
*
* @param str 待截取字符串,如果为null或者"",则立即返回str
* @param length 需要截取的长度
* @param endStr 截取后末尾追加的字符串
* @param charset 待截取字符串的编码
* @return
*/
public String subStringByByte(String str, int length, String endStr, String charset) {
if (str == null || "".equals(str.trim()) || length <= 0) {
return str;
}
try {
int strlen = str.getBytes(charset).length;// 这里要和页面的编码相关
if (strlen < length) return str;
Pattern p = Pattern.compile("^[""u4e00-""u9fa5]$");
int i = 0, j = 0;
int sublength = length - ((endStr == null) ? 0 : endStr.getBytes(charset).length);
for (char c : str.toCharArray()) {
Matcher m = p.matcher(String.valueOf(c));
i += m.find() ? 2 : 1;
++j;
if (i == sublength) break;
if (i > sublength) {
--j;
break;
}
}
return str.substring(0, j) + endStr;
} catch (UnsupportedEncodingException e) {
return str;
}
}