java判斷字符串中是否包含中文並過濾掉中文,具體內容如下
1.判斷字符串中是否包含中文方法封裝
/** * 判斷字符串中是否包含中文 * @param str * 待校驗字符串 * @return 是否爲中文 * @warn 不能校驗是否爲中文標點符號 */ public static boolean isContainChinese(String str) { Pattern p = Pattern.compile("[\u4e00-\u9fa5]"); Matcher m = p.matcher(str); if (m.find()) { return true; } return false; }
說明:需要導入
import java.util.regex.Matcher;
import java.util.regex.Pattern;
2.過濾中文
/** * 過濾掉中文 * @param str 待過濾中文的字符串 * @return 過濾掉中文後字符串 */ public static String filterChinese(String str) { // 用於返回結果 String result = str; boolean flag = isContainChinese(str); if (flag) {// 包含中文 // 用於拼接過濾中文後的字符 StringBuffer sb = new StringBuffer(); // 用於校驗是否爲中文 boolean flag2 = false; // 用於臨時存儲單字符 char chinese = 0; // 5.去除掉文件名中的中文 // 將字符串轉換成char[] char[] charArray = str.toCharArray(); // 過濾到中文及中文字符 for (int i = 0; i < charArray.length; i++) { chinese = charArray[i]; flag2 = isChinese(chinese); if (!flag2) {// 不是中日韓文字及標點符號 sb.append(chinese); } } result = sb.toString(); } return result; }