在頁面中顯示某字段時,字段值過長會導致頁面樣式錯亂,這時候我們需要對值進行截取,當截取值時會碰到以下問題:
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;
}
}