正则表达式及应用
|
|
匹配所有Moth DD,YYYY格式的日期
|
|
匹配所有Month DD,YYYY格式的日期,定义月份值为第一个组
|
|
匹配所有123-12-1234格式的社会安全号码
|
|
匹配IP地址
\d{1,3}\.\d{1,3}\.
|
|
匹配FONT标记的所有属性
|
private List
List
Pattern pattern = Pattern.compile(regexp);
Matcher matcher = pattern.matcher(str);
while (matcher.find()) {
if (!list.contains(matcher.group()))
list.add(matcher.group());
}
return list;
}
public static String convertAngleTag(String str) {
str = str.replaceAll("<", "<");
str = str.replaceAll(">", ">");
return str;
}
工具类:UbbToHtml.java
package com.steven.helper;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class UbbToHtml {
// 将ubb标签语言转成html
public static String convertUbbToHtml(String str) {
str = convertAngleTag(str);
str = convertCommentTag(str);
str = convertColorTag(str);
str = convertImgTag(str);
str = convertFieldsTag(str);
str = convertKeywordsTag(str);
str = convertJavaTag(str);
str = convertOtherTag(str);
return str;
}
// 将[code=img]和[/code]标签转成html
public static String convertImgTag(String str) {
if (str == null || str.length() == 0) {
return str;
}
String regexp = "(\\[code=img\\])([^\\[]+)(\\[/code\\])";
Pattern pattern = Pattern.compile(regexp);
Matcher match = pattern.matcher(str);
StringBuffer sb = new StringBuffer();
boolean result = match.find();
while (result) {
match.appendReplacement(sb, "");
result = match.find();
}
//match.appendTail(sb);
return sb.toString();
}
// 将[code=java]和[/code]标签转成html
public static String convertJavaTag(String str) {
if (str == null || str.length() == 0) {
return str;
}
String regexp = "(\\[code=java\\])\n?([\\s\\S]+?)(\\[/code\\])";
Pattern pattern = Pattern.compile(regexp);
Matcher match = pattern.matcher(str);
StringBuffer sb = new StringBuffer();
boolean result = match.find();
while (result) {
match.appendReplacement(sb, "" + match.group(2) + "");
result = match.find();
}
match.appendTail(sb);
return sb.toString();
}
// 将[color=blue]标签转成html
public static String convertColorTag(String str) {
if (str == null || str.length() == 0) {
return str;
}
String regexp = "(\\[color=blue\\])([^\\s]+)([\\s]+?)";
Pattern pattern = Pattern.compile(regexp);
Matcher match = pattern.matcher(str);
StringBuffer sb = new StringBuffer();
boolean result = match.find();
while (result) {
match.appendReplacement(sb,"" + match.group(2) + "");
result = match.find();
}
match.appendTail(sb);
return sb.toString();
}
// 将#[Fields]标签转成html
public static String convertFieldsTag(String str) {
if (str == null || str.length() == 0) {
return str;
}
String regexp = "(#\\[Fields\\])([^#]+?)#";
Pattern pattern = Pattern.compile(regexp);
Matcher match = pattern.matcher(str);
StringBuffer sb = new StringBuffer();
boolean result = match.find();
while (result) {
match.appendReplacement(sb,"" + match.group(2) + "");
result = match.find();
}
match.appendTail(sb);
return sb.toString();
}
// 将#[Keywords]标签转成html
public static String convertKeywordsTag(String str) {
if (str == null || str.length() == 0) {
return str;
}
String regexp = "(#\\[Keywords\\])(\\w+[\\s]?)";
Pattern pattern = Pattern.compile(regexp);
Matcher match = pattern.matcher(str);
StringBuffer sb = new StringBuffer();
boolean result = match.find();
while (result) {
match.appendReplacement(sb,"" + match.group(2) + "");
result = match.find();
}
match.appendTail(sb);
return sb.toString();
}
// 将#[Comments]标签转成html
public static String convertCommentTag(String str) {
if (str == null || str.length() == 0) {
return str;
}
String regexp = "(#\\[Comments\\]//)([^#]+)";
Pattern pattern = Pattern.compile(regexp);
Matcher match = pattern.matcher(str);
StringBuffer sb = new StringBuffer();
boolean result = match.find();
while (result) {
match.appendReplacement(sb, "//" + match.group(2) + "");
result = match.find();
}
match.appendTail(sb);
return sb.toString();
}
// 将\n换行标签及其他标签转成html
public static String convertOtherTag(String str) {
str = str.replaceAll("#\\}", "
}");
str = str.replaceAll("#", "");
str = str.replaceAll("\n", "
");
return str;
}
// 将左尖括号和右尖括号转成实体符号<和>。在html标签语言中,“<”和“>”会被认为是html标记。因此要先将其替换。
public static String convertAngleTag(String str) {
str = str.replaceAll("<", "<");
str = str.replaceAll(">", ">");
return str;
}
}
//调用页面只需要调用:String newStr = UbbToHtml.convertUbbToHtml(需要替换的字符串); 即可。
匹配特定数字:
^[1-9]d*$ //匹配正整数
^-[1-9]d*$ //匹配负整数
^-?[1-9]d*$ //匹配整数
^[1-9]d*|0$ //匹配非负整数(正整数 + 0)
^-[1-9]d*|0$ //匹配非正整数(负整数 + 0)
^[1-9]d*.d*|0.d*[1-9]d*$ //匹配正浮点数
^-([1-9]d*.d*|0.d*[1-9]d*)$ //匹配负浮点数
^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$ //匹配浮点数
^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$ //匹配非负浮点数(正浮点数 + 0)
^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$ //匹配非正浮点数(负浮点数 + 0)
匹配特定字符串:
^[A-Za-z]+$ //匹配由26个英文字母组成的字符串
^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串
^[a-z]+$ //匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$ //匹配由数字和26个英文字母组成的字符串
^w+$ //匹配由数字、26个英文字母或者下划线组成的字符串
只能输入数字:“^[0-9]*$”
只能输入n位的数字:“^d{n}$”
只能输入至少n位数字:“^d{n,}$”
只能输入m-n位的数字:“^d{m,n}$”
只能输入零和非零开头的数字:“^(0|[1-9][0-9]*)$”
只能输入有两位小数的正实数:“^[0-9]+(.[0-9]{2})?$”
只能输入有1-3位小数的正实数:“^[0-9]+(.[0-9]{1,3})?$”
只能输入非零的正整数:“^+?[1-9][0-9]*$”
只能输入非零的负整数:“^-[1-9][0-9]*$”
只能输入长度为3的字符:“^.{3}$”
只能输入由26个英文字母组成的字符串:“^[A-Za-z]+$”
只能输入由26个大写英文字母组成的字符串:“^[A-Z]+$”
只能输入由26个小写英文字母组成的字符串:“^[a-z]+$”
只能输入由数字和26个英文字母组成的字符串:“^[A-Za-z0-9]+$”
只能输入由数字、26个英文字母或者下划线组成的字符串:“^w+$”
验证用户密码:“^[a-zA-Z]w{5,17}$”正确格式为:以字母开头,长度在6-18之间,
只能包含字符、数字和下划线。
验证是否含有^%&’,;=?$”等字符:“[^%&’,;=?$x22]+”
只能输入汉字:“^[u4e00-u9fa5]{0,}$”
验证身份证号(15位或18位数字):“^d{15}|d{}18$”
验证一年的12个月:“^(0?[1-9]|1[0-2])$”正确格式为:“01”-“09”和“1”“12”
验证一个月的31天:“^((0?[1-9])|((1|2)[0-9])|30|31)$”
匹配中文字符的正则表达式: [u4e00-u9fa5]
匹配双字节字符(包括汉字在内):[^x00-xff]
匹配空行的正则表达式:n[s| ]*r
匹配HTML标记的正则表达式:/< (.*)>.*|< (.*) />/
匹配首尾空格的正则表达式:(^s*)|(s*$)
良心的公众号,更多精品文章,不要忘记关注哈
《Android和Java技术栈》