>我收到一个字符数组,其中包含有效和无效字符。我只需要检索有效的字符。我该怎么做?
char[]ch = str.toCharacterArray();
for(int i=0;i<ch.length.i++){
if(!Character.isLetter(ch[i]))
system.out.println("not valid");
else
system.out.println("valid");
}
我认为上面的代码不起作用,因为我对字符数组中的所有有效和无效字符都无效。
按含义字符,我期待所有字母数字和特殊字符
注意:我从服务器获取值,因此字符数组包含有效和无效字符。
尝试以下方法:
// assume input is not too large string
public static String extractPrintableChars(final String input) {
String out = input;
if(input != null) {
char[] charArr = input.toCharArray();
StringBuilder sb = new StringBuilder();
for (char ch : charArr) {
if(Character.isDefined(ch) && !Character.isISOControl(ch)) {
sb.append(ch);
}
}
out = sb.toString();
}
return out;
}
看看 Java 中可用的 Matcher 类。我认为在有最大上限之前遍历所有字符是不明智的。
/[^0-9]+/g, ''
使用上面的正则表达式,它将清除除数字以外的所有查克尔。根据需要修改它。
问候普尼斯