在项目中用到过.在字符串中有标点或其它字符,而只需要得到数字,汉字,英文这三种字符,所以需要过滤一下,代码如下.
/**
* @找出字串中的数字英文中文* @param s
* @return
*/
public static String specialFilters(String s){
String str="";
for (int i = 0; i < s.length(); i++) {
if (checkChs(s.substring(i, i+1))){
str=str+s.substring(i, i+1);
}else if(isNumber(s.substring(i, i+1))){//找是不是数字
str=str+s.substring(i, i+1);
}else if(isEnChar(s.substring(i, i+1))){
str=str+s.substring(i, i+1);
}
}
return ToDBC(str);
}
--------------------------可以加我微信号:googlecao 进行交流------------------------
* @数字正则
* @param s
* @return
*/
public static boolean isNumber(String s){
return s.matches("[0-9]*");
}
/**
* @英文正则
* @param s
* @return
*/
public static boolean isEnChar(String s){
return s.matches("[a-zA-Z]");
}
/**
* @汉字判断
* @param str
* @return
*/
public static boolean checkChs(String str) {
boolean mark = false;
Pattern pattern = Pattern.compile("[\u4E00-\u9FA5]");
Matcher matc = pattern.matcher(str);
StringBuffer stb = new StringBuffer();
while (matc.find()) {
mark = true;
stb.append(matc.group());
}
return mark;
}
/**
* 全角转半角
* @param input String.
* @return 半角字符串
*/
public static String ToDBC(String input) {
char c[] = input.toCharArray();
for (int i = 0; i < c.length; i++) {
if (c[i] == '\u3000') {
c[i] = ' ';
} else if (c[i] > '\uFF00' && c[i] < '\uFF5F') {
c[i] = (char) (c[i] - 65248);
}
}
String returnString = new String(c);
return returnString;
}