正则表达式的使用
这几天由于项目中的数据需要判断是否包含有效文字,所以就需要用到正则表达式。由于平时使用正则表达式的地方比较少,所以还是纠结了蛮久的。 首先看一下我用的这个正则表达式: String content1 = StrUtil.nullToStr(mContentET.getText().toString().trim()); String content = content1.replaceAll("s*|t|r|n",""); //过滤所有的空格、换行符、制表符 if (isReplayLz) {</span> if (!content.matches(".*[a-zA-Z0-9u4e00-u9fa5]+.*") && mPicPathList.size() < 3 || content.length() < 3&& mPicPathList.size() < 3) { AppManager.showToastMessageShort("字符数不少于3,且必须包含有意义的文字"); return; } addReply(); } else { if (!content.matches(".*[a-zA-Z0-9u4e00-u9fa5]+.*") && mPicPathList.size() < 3 || content.length() < 3&& mPicPathList.size() < 3) { AppManager.showToastMessageShort("字符数不少于3,且必须包含有意义的文字"); return; } addSubReply(content); }这里我是采用matches这个方法来匹配正则表达式的,当然还有其他方式,这里我就不多介绍了。主要还是说明一下.*[a-zA-Z0-9u4e00-u9fa5]+.*这个正则表达式的意义: 前面的 . * 代表任意字符 [ ]代表一个分组里面的内容就是一个整体 a-z代表包含所有的小写字母 A-Z代表包含所有的大写字母 0-9代表包含所有数字,也可以用d表示 +代表,[ ]中的字符可以有1个或多个,至少有一个也可以用{1,}来表示 ^表示以。。为开头 $表示以。。为结尾 纠正一点: . * 这个符号并不能代表任意字符,因为这个点,是排除了n换行符的。所以正确的写法应该是: [sS]* 、[dD]*、[wW]* s:用于匹配单个空格符,包括tab键和换行符; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |