- 浏览: 424867 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (184)
- IDE (4)
- dotCMS (3)
- Liferay Portal (1)
- J2EE (7)
- My SQL (16)
- IBM DB2 (3)
- Oracle (2)
- JDBC (4)
- Hibernate (3)
- JSP (0)
- Framework (4)
- Java编程 (30)
- C++编程 (0)
- Struts 1.X (2)
- Struts 2.X (6)
- Linux (11)
- Spring (7)
- JavaScript (6)
- Ajax (2)
- XML (3)
- IBM Websphere Portal (1)
- IBM Lotus Quickr (1)
- CMS (2)
- ERP (0)
- CRM (0)
- 大型网站架构开发 (1)
- 面试武器 (2)
- HTML 5 (2)
- dTree && webFxloadTree (2)
- JVM (7)
- SQL Server (3)
- Tomcat && Apache && Jboss && Weblogic-中间件 (4)
- FreeMarker (2)
- MongoDB (7)
- OpenSource开源 (24)
- Cloud (0)
- FFmpeg (3)
- Thrift (1)
- SpringSide (1)
- Design Pattern (1)
- solr&&ES (2)
- git&svn (1)
- 大数据 (8)
- 人工智能 (0)
- Hadoop (3)
- Spark (0)
- Sqoop (1)
- Flume (1)
- Hive (3)
- HDFS (4)
- ES (0)
- Redis (1)
- Kafka (3)
- MR (0)
- 机器学习 (0)
- 深度学习 (0)
- Impala (2)
- HBase (2)
- Spring Boot (1)
- Spring Cloud (0)
- 大数据架构 (6)
- 架构思想理论 (6)
- 技术管理 (4)
- 数据结构与算法 (4)
最新评论
-
huijz:
...
Spring Data JPA研究-使用Spring Data JPA 简化JPA 开发(ZZ) -
用户名不存在:
[img][/img][*]引用[u][/u][i][/i][ ...
MongoDB 模糊查询的三种实现方式-morphia实现 -
junsheng100:
请给个完整的例子吧!包括jar文件等
java调用ffmpeg获取视频文件信息参数代码 -
mj:
谢谢!!
SQL Server里面如何导出包含(insert into)数据的SQL脚本 (转载ZZ)
关键字: java 正则表达式 regular
Java代码
1.public class RegularTest {
2. public static void main(String[] args){
3. p("str".matches("..."));
4. //public String replaceAll(String regex, String replacement)
5. //public String replaceFirst(String regex, String replacement)
6. p("A00123lB".replaceFirst("\\d","*"));
7. p("A00123lB".replaceAll("\\d", "*"));
8.// []表示范围,{}表示长度
9.// [0-9]表示在0到9之前的一个数
10.// \\d{0,10}表示0到10之间的长度
11.// Greedy 数量词
12.// X? X,一次或一次也没有
13.// X* X,零次或多次
14.// X+ X,一次或多次
15.// X{n} X,恰好 n 次
16.// X{n,} X,至少 n 次
17.// X{n,m} X,至少 n 次,但是不超过 m 次
18.// "\\" 匹配 反斜线字符(\)
19.// "\\".matches("\\\\") 一个\匹配的时候要写四个
20.// [abc] a、b 或 c(简单类)
21.// [^abc] 任何字符,除了 a、b 或 c(否定)
22.// [a-zA-Z] a 到 z 或 A 到 Z,两头的字母包括在内(范围)(并集[a-z]|[A-Z])
23.// [a-d[m-p]] a 到 d 或 m 到 p:[a-dm-p](并集)
24.// [a-z&&[def]] d、e 或 f(交集)
25.// [a-z&&[^bc]] a 到 z,除了 b 和 c:[ad-z](减去)
26.// [a-z&&[^m-p]] a 到 z,而非 m 到 p:[a-lq-z](减去)
27.
28.// . 任何字符(与行结束符可能匹配也可能不匹配)
29.// \d 数字:[0-9]
30.// \D 非数字: [^0-9]
31.// \s 空白字符:[ \t\n\x0B\f\r]
32.// \S 非空白字符:[^\s]
33.// \w 单词字符:[a-zA-Z_0-9]
34.// \W 非单词字符:[^\w]
35.// ^ 行的开头
36.// $ 行的结尾
37.// \b 单词边界
38.// \B 非单词边界
39.// p(" \n".matches("^[\\s&&[^\\n]]*\\n$"));这个匹配空白字付(开始是空白,但不是换行,结果是换行)
40.// p("hello sir".matches("^h.*r$"));
41.// "lan ".matches(".*\\z$") 这样的不能单词边界,要用行的结尾\z
42.
43.// Reluctant 数量词(这个是勉强的,先用最少的去匹配)
44.// X?? X,一次或一次也没有
45.// X*? X,零次或多次
46.// X+? X,一次或多次
47.// X{n}? X,恰好 n 次
48.// X{n,}? X,至少 n 次
49.// X{n,m}? X,至少 n 次,但是不超过 m 次
50.
51.// Possessive 数量词 (这个用来追求效率,直接打最多的,不行的话就不行了)
52.// X?+ X,一次或一次也没有
53.// X*+ X,零次或多次
54.// X++ X,一次或多次
55.// X{n}+ X,恰好 n 次
56.// X{n,}+ X,至少 n 次
57.// X{n,m}+ X,至少 n 次,但是不超过 m 次
58.// 文字替换(首次出现字符)
59.// Pattern pattern = Pattern.compile("正则表达式");
60.// Matcher matcher = pattern.matcher("正则表达式 Hello World,正则表达式 Hello World");
61.// 替换第一个符合正则的数据
62.// System.out.println(matcher.replaceFirst("Java"));
63.//
64.// 文字替换(全部)
65.// Pattern pattern = Pattern.compile("正则表达式");
66.// Matcher matcher = pattern.matcher("正则表达式 Hello World,正则表达式 Hello World");
67.// 替换第一个符合正则的数据
68.// System.out.println(matcher.replaceAll("Java"));
69.// 去除html标记
70.// Pattern pattern = Pattern.compile("<.+?>", Pattern.DOTALL);
71.// Matcher matcher = pattern.matcher("<a href=\"index.html\">主页</a>");
72.// String string = matcher.replaceAll("");
73.// System.out.println(string);
74.
75.// 截取http://地址
76.// 截取url
77.// Pattern pattern = Pattern.compile("(http://|https://){1}[\\w\\.\\-/:]+");
78.// Matcher matcher = pattern.matcher("dsdsds<http://dsds//gfgffdfd>fdf");
79.// StringBuffer buffer = new StringBuffer();
80.// while(matcher.find()){
81.// buffer.append(matcher.group());
82.// buffer.append("\r\n");
83.// System.out.println(buffer.toString());
84.// }
85.// 匹配中文的Regular [\\u4e00-\\u9fa5]
86.
87. //电子邮件的匹配
88. Pattern email = Pattern.compile("[\\w[.-]]+@[\\w[.-]]+\\.[\\w]+");
89. Matcher emailMatcher = email.matcher("langhu@qq.com");
90. //Matcher是匹配整个字符串
91. //find()找子串,start()找到子串开始的位置,end()找到子串结束的位置,
92. //但必须能找到子串才能用start,end这两个方法reset()重置
93. p(emailMatcher.matches());
94.
95. //appendReplacement()和appendTail()方法
96. //忽略大小写Pattern.CASE_INSENSITIVE
97. String str = "langhua lanHUA LANghua lANGHUa dsfd LANGHUA T";
98. Pattern langhuaParttern = Pattern.compile("langhua", Pattern.CASE_INSENSITIVE);
99. Matcher langhuaMatcher = langhuaParttern.matcher(str);
100. StringBuffer sb = new StringBuffer();
101. int i = 0;
102. while(langhuaMatcher.find()){
103. i++;
104. if(i%2==0){
105. langhuaMatcher.appendReplacement(sb,"xiaolanghua");
106. }else{
107. langhuaMatcher.appendReplacement(sb,"dalanghua");
108. }
109. }
110. langhuaMatcher.appendTail(sb);
111. p(sb.toString());
112. //分组group()返回的是子串
113. String num = "123aa-1234aa-12384bb-0-*-*";
114. Pattern nump = Pattern.compile("(\\d{3,5})(\\w{2})");
115. Matcher numm = nump.matcher(num);
116. while(numm.find()){
117. p(numm.group(1));
118. }
119.
120. Pattern pattern = Pattern.compile(".{1,3}?\\d");
121. Matcher marcher = pattern.matcher("2地3基13ab2cef2");
122. if(marcher.find()){
123. p(marcher.group());
124. p(marcher.start()+"-"+marcher.end());
125. }
126. }
127. public static void p(Object o){
128. System.out.println(o);
129. }
130.}
=============================================================
string.replaceAll()中的特殊字符($ \)与matcher.appendReplacement
string.replaceAll中的特殊字符
string.replaceAll(String regex, String replacement)中的replacement参数即替换内容中含有特殊字符 $ \ 时,需转义。
Java代码
1./*
2. * 字符串"$ \"中的$与\字符互换位置
3. */
4.public class SpecialCharReplace {
5. public static void main(String[] args) {
6. String str = "$ \\";
7. /*
8. * string.replaceAll()中的特殊字符 $ 与 \
9. *
10. * 由于 $ 字符在作为替换内容时,是一个特殊字符,指反向引用前面的分组内容,所以把
11. * 某字符替换成 $ 字符时,因该在前面加上转义字符 \。
12. * \ 字符就不用说了,本身就是转义字符,但为什么在作为替换内容时要使用四个 \ 字符
13. * ,这里又不是用在正则表达式里?这就是因为 \ 字符在作为替换内容里也是一个特殊字
14. * 符,它用来将前面讲的 $ 字符进行转换的,所以也为特殊字符。以下是replaceAll的
15. * 源码片断,从源码就可以看出 \$ 是两个特殊字符
16. *
17. * if (nextChar == '\\') {
18. * cursor++;
19. * nextChar = replacement.charAt(cursor);
20. * result.append(nextChar);
21. * cursor++;
22. * } else if (nextChar == '$') {
23. * // Skip past $
24. * cursor++;
25. * ...
26. * }else {
27. * result.append(nextChar);
28. * cursor++;
29. * }
30. */
31. System.out.println(str.replaceAll("\\$(\\W)\\\\", "\\\\$1\\$"));// \ $
32. }
33.
34.}
/*
* 字符串"$ \"中的$与\字符互换位置
*/
public class SpecialCharReplace {
public static void main(String[] args) {
String str = "$ \\";
/*
* string.replaceAll()中的特殊字符 $ 与 \
*
* 由于 $ 字符在作为替换内容时,是一个特殊字符,指反向引用前面的分组内容,所以把
* 某字符替换成 $ 字符时,因该在前面加上转义字符 \。
* \ 字符就不用说了,本身就是转义字符,但为什么在作为替换内容时要使用四个 \ 字符
* ,这里又不是用在正则表达式里?这就是因为 \ 字符在作为替换内容里也是一个特殊字
* 符,它用来将前面讲的 $ 字符进行转换的,所以也为特殊字符。以下是replaceAll的
* 源码片断,从源码就可以看出 \$ 是两个特殊字符
*
* if (nextChar == '\\') {
* cursor++;
* nextChar = replacement.charAt(cursor);
* result.append(nextChar);
* cursor++;
* } else if (nextChar == '$') {
* // Skip past $
* cursor++;
* ...
* }else {
* result.append(nextChar);
* cursor++;
* }
*/
System.out.println(str.replaceAll("\\$(\\W)\\\\", "\\\\$1\\$"));// \ $
}
} Matcher对象的appendReplacement典型应用与特殊字符&\的进一步分析
问题的提出
字符串模板:
String template="尊敬的客户${customerName}你好!本次消费金额${amount},您帐户${accountNumber}上的余额为${balance},欢迎下次光临!";
其中以 ${ 开始 } 结尾的为待替换的变量域。
数据存放于Map中,key为域名,value为域值。如:
Map--
customerName = 刘明
accountNumber = 888888888
balance = $1000000.00
amount = $1000.00
请编写函数:
public static String composeMessage(String template, Map data) throw Exception
实现将任意模板字符串中的变量域,按域名替换为data中的域值。
例如,上例替换结果为:
"尊敬的客户刘明你好!本次消费金额$1000.00,您帐户888888888上的余额为$1000000.00,欢迎下次光临!"
注:如果Map中找不到域值,以空字符串""替换。
问题的解决
Java代码
1.public class RegexExam {
2. public static void main(String args[]) {
3. HashMap data = new HashMap();
4. String template = "尊敬的客户${customerName}你好!本次消费金额${amount},"
5. + "您帐户${accountNumber}上的余额为${balance},欢迎下次光临!";
6. data.put("customerName", "刘明");
7. data.put("accountNumber", "888888888");
8. data.put("balance", "$1000000.00");
9. data.put("amount", "$1000.00");
10. try {
11. System.out.println(composeMessage(template, data));
12. } catch (Exception e) {
13. e.printStackTrace();
14. }
15. }
16.
17. public static String composeMessage(String template, Map data)
18. throws Exception {
19. String regex = "\\$\\{(.+?)\\}";
20. Pattern pattern = Pattern.compile(regex);
21. Matcher matcher = pattern.matcher(template);
22. /*
23. * sb用来存储替换过的内容,它会把多次处理过的字符串按源字符串序
24. * 存储起来。
25. */
26. StringBuffer sb = new StringBuffer();
27. while (matcher.find()) {
28. String name = matcher.group(1);//键名
29. String value = (String) data.get(name);//键值
30. if (value == null) {
31. value = "";
32. } else {
33. /*
34. * 由于$出现在replacement中时,表示对捕获组的反向引用,所以要对上面替换内容
35. * 中的 $ 进行替换,让它们变成 "\$1000.00" 或 "\$1000000000.00" ,这样
36. * 在下面使用 matcher.appendReplacement(sb, value) 进行替换时就不会把
37. * $1 看成是对组的反向引用了,否则会使用子匹配项值amount 或 balance替换 $1
38. * ,最后会得到错误结果:
39. *
40. * 尊敬的客户刘明你好!本次消费金额amount000.00,您帐户888888888上的余额
41. * 为balance000000.00,欢迎下次光临!
42. *
43. * 要把 $ 替换成 \$ ,则要使用 \\\\\\& 来替换,因为一个 \ 要使用 \\\ 来进
44. * 行替换,而一个 $ 要使用 \\$ 来进行替换,因 \ 与 $ 在作为替换内容时都属于
45. * 特殊字符:$ 字符表示反向引用组,而 \ 字符又是用来转义 $ 字符的。
46. */
47. value = value.replaceAll("\\$", "\\\\\\$");
48. //System.out.println("value=" + value);
49. }
50. /*
51. * 经过上面的替换操作,现在的 value 中含有 $ 特殊字符的内容被换成了"\$1000.00"
52. * 或 "\$1000000000.00" 了,最后得到下正确的结果:
53. *
54. * 尊敬的客户刘明你好!本次消费金额$1000.00,您帐户888888888上的
55. * 余额为$1000000.00,欢迎下次光临!
56. *
57. * 另外,我们在这里使用Matcher对象的appendReplacement()方法来进行替换操作,而
58. * 不是使用String对象的replaceAll()或replaceFirst()方法来进行替换操作,因为
59. * 它们都能只能进行一次性简单的替换操作,而且只能替换成一样的内容,而这里则是要求每
60. * 一个匹配式的替换值都不同,所以就只能在循环里使用appendReplacement方式来进行逐
61. * 个替换了。
62. */
63. matcher.appendReplacement(sb, value);
64. System.out.println("sb = " + sb.toString());
65. }
66. //最后还得要把尾串接到已替换的内容后面去,这里尾串为“,欢迎下次光临!”
67. matcher.appendTail(sb);
68. return sb.toString();
69. }
70.}
Java代码
1.public class RegularTest {
2. public static void main(String[] args){
3. p("str".matches("..."));
4. //public String replaceAll(String regex, String replacement)
5. //public String replaceFirst(String regex, String replacement)
6. p("A00123lB".replaceFirst("\\d","*"));
7. p("A00123lB".replaceAll("\\d", "*"));
8.// []表示范围,{}表示长度
9.// [0-9]表示在0到9之前的一个数
10.// \\d{0,10}表示0到10之间的长度
11.// Greedy 数量词
12.// X? X,一次或一次也没有
13.// X* X,零次或多次
14.// X+ X,一次或多次
15.// X{n} X,恰好 n 次
16.// X{n,} X,至少 n 次
17.// X{n,m} X,至少 n 次,但是不超过 m 次
18.// "\\" 匹配 反斜线字符(\)
19.// "\\".matches("\\\\") 一个\匹配的时候要写四个
20.// [abc] a、b 或 c(简单类)
21.// [^abc] 任何字符,除了 a、b 或 c(否定)
22.// [a-zA-Z] a 到 z 或 A 到 Z,两头的字母包括在内(范围)(并集[a-z]|[A-Z])
23.// [a-d[m-p]] a 到 d 或 m 到 p:[a-dm-p](并集)
24.// [a-z&&[def]] d、e 或 f(交集)
25.// [a-z&&[^bc]] a 到 z,除了 b 和 c:[ad-z](减去)
26.// [a-z&&[^m-p]] a 到 z,而非 m 到 p:[a-lq-z](减去)
27.
28.// . 任何字符(与行结束符可能匹配也可能不匹配)
29.// \d 数字:[0-9]
30.// \D 非数字: [^0-9]
31.// \s 空白字符:[ \t\n\x0B\f\r]
32.// \S 非空白字符:[^\s]
33.// \w 单词字符:[a-zA-Z_0-9]
34.// \W 非单词字符:[^\w]
35.// ^ 行的开头
36.// $ 行的结尾
37.// \b 单词边界
38.// \B 非单词边界
39.// p(" \n".matches("^[\\s&&[^\\n]]*\\n$"));这个匹配空白字付(开始是空白,但不是换行,结果是换行)
40.// p("hello sir".matches("^h.*r$"));
41.// "lan ".matches(".*\\z$") 这样的不能单词边界,要用行的结尾\z
42.
43.// Reluctant 数量词(这个是勉强的,先用最少的去匹配)
44.// X?? X,一次或一次也没有
45.// X*? X,零次或多次
46.// X+? X,一次或多次
47.// X{n}? X,恰好 n 次
48.// X{n,}? X,至少 n 次
49.// X{n,m}? X,至少 n 次,但是不超过 m 次
50.
51.// Possessive 数量词 (这个用来追求效率,直接打最多的,不行的话就不行了)
52.// X?+ X,一次或一次也没有
53.// X*+ X,零次或多次
54.// X++ X,一次或多次
55.// X{n}+ X,恰好 n 次
56.// X{n,}+ X,至少 n 次
57.// X{n,m}+ X,至少 n 次,但是不超过 m 次
58.// 文字替换(首次出现字符)
59.// Pattern pattern = Pattern.compile("正则表达式");
60.// Matcher matcher = pattern.matcher("正则表达式 Hello World,正则表达式 Hello World");
61.// 替换第一个符合正则的数据
62.// System.out.println(matcher.replaceFirst("Java"));
63.//
64.// 文字替换(全部)
65.// Pattern pattern = Pattern.compile("正则表达式");
66.// Matcher matcher = pattern.matcher("正则表达式 Hello World,正则表达式 Hello World");
67.// 替换第一个符合正则的数据
68.// System.out.println(matcher.replaceAll("Java"));
69.// 去除html标记
70.// Pattern pattern = Pattern.compile("<.+?>", Pattern.DOTALL);
71.// Matcher matcher = pattern.matcher("<a href=\"index.html\">主页</a>");
72.// String string = matcher.replaceAll("");
73.// System.out.println(string);
74.
75.// 截取http://地址
76.// 截取url
77.// Pattern pattern = Pattern.compile("(http://|https://){1}[\\w\\.\\-/:]+");
78.// Matcher matcher = pattern.matcher("dsdsds<http://dsds//gfgffdfd>fdf");
79.// StringBuffer buffer = new StringBuffer();
80.// while(matcher.find()){
81.// buffer.append(matcher.group());
82.// buffer.append("\r\n");
83.// System.out.println(buffer.toString());
84.// }
85.// 匹配中文的Regular [\\u4e00-\\u9fa5]
86.
87. //电子邮件的匹配
88. Pattern email = Pattern.compile("[\\w[.-]]+@[\\w[.-]]+\\.[\\w]+");
89. Matcher emailMatcher = email.matcher("langhu@qq.com");
90. //Matcher是匹配整个字符串
91. //find()找子串,start()找到子串开始的位置,end()找到子串结束的位置,
92. //但必须能找到子串才能用start,end这两个方法reset()重置
93. p(emailMatcher.matches());
94.
95. //appendReplacement()和appendTail()方法
96. //忽略大小写Pattern.CASE_INSENSITIVE
97. String str = "langhua lanHUA LANghua lANGHUa dsfd LANGHUA T";
98. Pattern langhuaParttern = Pattern.compile("langhua", Pattern.CASE_INSENSITIVE);
99. Matcher langhuaMatcher = langhuaParttern.matcher(str);
100. StringBuffer sb = new StringBuffer();
101. int i = 0;
102. while(langhuaMatcher.find()){
103. i++;
104. if(i%2==0){
105. langhuaMatcher.appendReplacement(sb,"xiaolanghua");
106. }else{
107. langhuaMatcher.appendReplacement(sb,"dalanghua");
108. }
109. }
110. langhuaMatcher.appendTail(sb);
111. p(sb.toString());
112. //分组group()返回的是子串
113. String num = "123aa-1234aa-12384bb-0-*-*";
114. Pattern nump = Pattern.compile("(\\d{3,5})(\\w{2})");
115. Matcher numm = nump.matcher(num);
116. while(numm.find()){
117. p(numm.group(1));
118. }
119.
120. Pattern pattern = Pattern.compile(".{1,3}?\\d");
121. Matcher marcher = pattern.matcher("2地3基13ab2cef2");
122. if(marcher.find()){
123. p(marcher.group());
124. p(marcher.start()+"-"+marcher.end());
125. }
126. }
127. public static void p(Object o){
128. System.out.println(o);
129. }
130.}
=============================================================
string.replaceAll()中的特殊字符($ \)与matcher.appendReplacement
string.replaceAll中的特殊字符
string.replaceAll(String regex, String replacement)中的replacement参数即替换内容中含有特殊字符 $ \ 时,需转义。
Java代码
1./*
2. * 字符串"$ \"中的$与\字符互换位置
3. */
4.public class SpecialCharReplace {
5. public static void main(String[] args) {
6. String str = "$ \\";
7. /*
8. * string.replaceAll()中的特殊字符 $ 与 \
9. *
10. * 由于 $ 字符在作为替换内容时,是一个特殊字符,指反向引用前面的分组内容,所以把
11. * 某字符替换成 $ 字符时,因该在前面加上转义字符 \。
12. * \ 字符就不用说了,本身就是转义字符,但为什么在作为替换内容时要使用四个 \ 字符
13. * ,这里又不是用在正则表达式里?这就是因为 \ 字符在作为替换内容里也是一个特殊字
14. * 符,它用来将前面讲的 $ 字符进行转换的,所以也为特殊字符。以下是replaceAll的
15. * 源码片断,从源码就可以看出 \$ 是两个特殊字符
16. *
17. * if (nextChar == '\\') {
18. * cursor++;
19. * nextChar = replacement.charAt(cursor);
20. * result.append(nextChar);
21. * cursor++;
22. * } else if (nextChar == '$') {
23. * // Skip past $
24. * cursor++;
25. * ...
26. * }else {
27. * result.append(nextChar);
28. * cursor++;
29. * }
30. */
31. System.out.println(str.replaceAll("\\$(\\W)\\\\", "\\\\$1\\$"));// \ $
32. }
33.
34.}
/*
* 字符串"$ \"中的$与\字符互换位置
*/
public class SpecialCharReplace {
public static void main(String[] args) {
String str = "$ \\";
/*
* string.replaceAll()中的特殊字符 $ 与 \
*
* 由于 $ 字符在作为替换内容时,是一个特殊字符,指反向引用前面的分组内容,所以把
* 某字符替换成 $ 字符时,因该在前面加上转义字符 \。
* \ 字符就不用说了,本身就是转义字符,但为什么在作为替换内容时要使用四个 \ 字符
* ,这里又不是用在正则表达式里?这就是因为 \ 字符在作为替换内容里也是一个特殊字
* 符,它用来将前面讲的 $ 字符进行转换的,所以也为特殊字符。以下是replaceAll的
* 源码片断,从源码就可以看出 \$ 是两个特殊字符
*
* if (nextChar == '\\') {
* cursor++;
* nextChar = replacement.charAt(cursor);
* result.append(nextChar);
* cursor++;
* } else if (nextChar == '$') {
* // Skip past $
* cursor++;
* ...
* }else {
* result.append(nextChar);
* cursor++;
* }
*/
System.out.println(str.replaceAll("\\$(\\W)\\\\", "\\\\$1\\$"));// \ $
}
} Matcher对象的appendReplacement典型应用与特殊字符&\的进一步分析
问题的提出
字符串模板:
String template="尊敬的客户${customerName}你好!本次消费金额${amount},您帐户${accountNumber}上的余额为${balance},欢迎下次光临!";
其中以 ${ 开始 } 结尾的为待替换的变量域。
数据存放于Map中,key为域名,value为域值。如:
Map--
customerName = 刘明
accountNumber = 888888888
balance = $1000000.00
amount = $1000.00
请编写函数:
public static String composeMessage(String template, Map data) throw Exception
实现将任意模板字符串中的变量域,按域名替换为data中的域值。
例如,上例替换结果为:
"尊敬的客户刘明你好!本次消费金额$1000.00,您帐户888888888上的余额为$1000000.00,欢迎下次光临!"
注:如果Map中找不到域值,以空字符串""替换。
问题的解决
Java代码
1.public class RegexExam {
2. public static void main(String args[]) {
3. HashMap data = new HashMap();
4. String template = "尊敬的客户${customerName}你好!本次消费金额${amount},"
5. + "您帐户${accountNumber}上的余额为${balance},欢迎下次光临!";
6. data.put("customerName", "刘明");
7. data.put("accountNumber", "888888888");
8. data.put("balance", "$1000000.00");
9. data.put("amount", "$1000.00");
10. try {
11. System.out.println(composeMessage(template, data));
12. } catch (Exception e) {
13. e.printStackTrace();
14. }
15. }
16.
17. public static String composeMessage(String template, Map data)
18. throws Exception {
19. String regex = "\\$\\{(.+?)\\}";
20. Pattern pattern = Pattern.compile(regex);
21. Matcher matcher = pattern.matcher(template);
22. /*
23. * sb用来存储替换过的内容,它会把多次处理过的字符串按源字符串序
24. * 存储起来。
25. */
26. StringBuffer sb = new StringBuffer();
27. while (matcher.find()) {
28. String name = matcher.group(1);//键名
29. String value = (String) data.get(name);//键值
30. if (value == null) {
31. value = "";
32. } else {
33. /*
34. * 由于$出现在replacement中时,表示对捕获组的反向引用,所以要对上面替换内容
35. * 中的 $ 进行替换,让它们变成 "\$1000.00" 或 "\$1000000000.00" ,这样
36. * 在下面使用 matcher.appendReplacement(sb, value) 进行替换时就不会把
37. * $1 看成是对组的反向引用了,否则会使用子匹配项值amount 或 balance替换 $1
38. * ,最后会得到错误结果:
39. *
40. * 尊敬的客户刘明你好!本次消费金额amount000.00,您帐户888888888上的余额
41. * 为balance000000.00,欢迎下次光临!
42. *
43. * 要把 $ 替换成 \$ ,则要使用 \\\\\\& 来替换,因为一个 \ 要使用 \\\ 来进
44. * 行替换,而一个 $ 要使用 \\$ 来进行替换,因 \ 与 $ 在作为替换内容时都属于
45. * 特殊字符:$ 字符表示反向引用组,而 \ 字符又是用来转义 $ 字符的。
46. */
47. value = value.replaceAll("\\$", "\\\\\\$");
48. //System.out.println("value=" + value);
49. }
50. /*
51. * 经过上面的替换操作,现在的 value 中含有 $ 特殊字符的内容被换成了"\$1000.00"
52. * 或 "\$1000000000.00" 了,最后得到下正确的结果:
53. *
54. * 尊敬的客户刘明你好!本次消费金额$1000.00,您帐户888888888上的
55. * 余额为$1000000.00,欢迎下次光临!
56. *
57. * 另外,我们在这里使用Matcher对象的appendReplacement()方法来进行替换操作,而
58. * 不是使用String对象的replaceAll()或replaceFirst()方法来进行替换操作,因为
59. * 它们都能只能进行一次性简单的替换操作,而且只能替换成一样的内容,而这里则是要求每
60. * 一个匹配式的替换值都不同,所以就只能在循环里使用appendReplacement方式来进行逐
61. * 个替换了。
62. */
63. matcher.appendReplacement(sb, value);
64. System.out.println("sb = " + sb.toString());
65. }
66. //最后还得要把尾串接到已替换的内容后面去,这里尾串为“,欢迎下次光临!”
67. matcher.appendTail(sb);
68. return sb.toString();
69. }
70.}
发表评论
-
Java应用OOM内存过高解决及优化
2022-04-27 17:49 1021JVM OOM优化 jmap -heap 303 ... -
哈希算法与MurmurHash3
2022-04-12 15:25 1576MurmurHash 哈希算法 ... -
SQL注入攻击防范研究
2021-12-27 15:25 228SQL注入攻击如何攻击的: JDBC Statemen ... -
IDEA快捷键
2021-12-23 15:53 370IDEA快捷键 1.创建main函数快捷键 在编写代码 ... -
JAVA 8的Lambda表达式和Stream API研究
2018-03-21 17:31 769JAVA 8 Lambda表达式简化了代码开发,代码简洁, ... -
ThreadPoolExecutor里面4种拒绝策略(转)
2017-12-14 18:03 3165ThreadPoolExecutor类实现了Executo ... -
MySQL函数研究总结-CONCAT、REPLACE、ROUND、FLOOR和CEILING、TRUNCATE、CASE WHEN等
2017-02-20 16:26 1584CONCAT、REPLACE、ROUND、FLOOR和CEI ... -
itext实现PDF生成的两种方式-从HTML到PDF
2017-01-18 14:38 10995itext实现PDF生成的两种方式-从HTML到PDF ... -
Java处理Http请求的几种方式总结
2017-01-10 18:17 95031.commons-httpclient 简洁快速模拟H ... -
javaMelody监控接入使用
2016-03-03 23:55 14001.jar pom <!-- javamelody ... -
多线程-java线程池使用
2016-03-01 16:46 1222(一) new Thread(new SolrDataH ... -
java.io.IOException: Too many open files解决方案
2013-03-06 15:35 11818异常:java.io.IOException: Too m ... -
Guava(石榴)使用研究-Google开源Collection类库
2013-01-29 18:33 13481)Guava 简介 Guava 中文是石榴的意思,该项 ... -
Joda-Time&Date4j使用研究-开源JAVA日期时间处理类库
2013-01-29 18:27 22371)Joda-Time简介 Joda-Time提供了一组 ... -
Maven常用配置及Tomcat插件配置
2013-01-25 12:54 17281Maven用了一段时间了,基本上被我摆平了。结合Eclip ... -
GitHub无法访问,修改hosts文件解决
2013-01-22 15:30 1137前几天由于12306的抢票 ... -
MD5加密的几种实现方式研究
2013-01-10 17:08 2518MD5加密的几种实现方式如下: 一、第一种方式 Diges ... -
JAVA 定时方式大总结
2012-05-17 19:38 1470JAVA 定时方式大总结 除了Quartz之外,JAV ... -
获取spring容器applicationContext的几种方式
2012-04-13 10:39 2280一、定义web.xml,由web容器自动加载配置文件初始 ... -
J2EE快速开发框架wabacus3.2简介
2012-03-16 18:45 2144J2EE快速开发框架wabacus 3.2 发布,提高J ...
相关推荐
Java正则表达式是Java编程语言中用于处理字符串的强大工具,它基于模式匹配的概念,能够高效地进行文本搜索、替换和解析。在Java中,正则表达式主要通过`java.util.regex`包来实现,提供了Pattern和Matcher两个核心...
Java正则表达式匹配工具是IT领域中一种强大的文本处理工具,它利用正则表达式(Regular Expression)的规则来查找、替换或者提取文本中的特定模式。正则表达式是一种特殊的字符序列,能够帮助程序员或者用户高效地...
Java正则表达式验证IP地址 Java正则表达式验证IP地址是指使用Java语言中的正则表达式来验证IP地址是否符合标准。IP地址是指在网络通信中用来标识设备的地址,它是一种逻辑地址,通过它可以找到网络中的设备。在...
Java正则表达式是编程语言Java中的一个强大工具,它用于模式匹配、数据验证和文本检索替换。在Java中,正则表达式是通过java.util.regex包提供的接口和类来实现的。`regex-smart.jar`这个库显然是为了简化开发者在...
本篇将围绕“使用Java正则表达式分析处理日志”这一主题,探讨如何利用Java的正则表达式功能来提取、过滤和操作日志数据。 首先,我们需要理解正则表达式的基本概念。正则表达式(Regular Expression)是一种模式...
以下是对这些文档标题所涉及的Java正则表达式知识点的详细解释: 1. **正则表达式之道** 这个主题可能涵盖了正则表达式的基础概念,包括元字符、字符类、量词和分组。元字符如`.`代表任意字符,`^`表示行首,`$`...
Java正则表达式是一种强大的文本处理工具,广泛用于验证字符串、查找特定模式和替换文本。在Java中,正则表达式提供了简洁而灵活的方式来处理字符串,使得编程人员能够以更高效的方式实现各种文本操作。 正则表达式...
Java正则表达式库是Java开发中不可或缺的一部分,它为开发者提供了一种强大的文本匹配工具。在Java中,正则表达式(Regular Expression)是一种模式匹配语言,用于处理字符串操作,如查找、替换或提取特定模式的数据...
Java正则表达式测试工具是面向开发者和爱好者的一款实用程序,它可以帮助用户验证和调试他们的正则表达式。在Java编程环境中,正则表达式是一个强大的字符串处理工具,广泛用于数据验证、文本搜索和替换等任务。这款...
### 使用Java正则表达式实现一个简单的身份证号码验证 #### 一、背景介绍 身份证号码是中国公民的身份标识,由15位或18位数字组成(早期为15位,后改为18位)。其中,第18位是校验码,可能是数字0~9或者大写字母X。...
### 常用Java正则表达式知识点 #### 一、引言 正则表达式是一种强大的工具,用于处理文本并查找模式。多种编程语言,包括Perl、PHP、Python、JavaScript以及Java等均内置了对正则表达式的支持。本文将详细介绍Java...
Java正则表达式是Java编程语言中用于处理字符串的强大工具,它允许我们通过模式匹配来查找、替换或分割文本。这个“java正则表达式截取demo”提供了一个可以直接运行的示例,帮助开发者理解如何在Java中使用正则...
Java正则表达式是Java编程语言中的一个强大工具,它用于模式匹配和字符串处理,尤其在数据验证、文本检索和替换等方面发挥着重要作用。本教程是专为初学者设计的HTML版,旨在帮助读者快速掌握Java正则表达式的概念和...
Java正则表达式是Java编程语言中用于处理字符串的强大工具,它允许我们通过模式匹配来查找、替换或分割文本。在Android开发中,正则表达式尤其重要,因为它们可以帮助我们验证用户输入、处理文本数据或者进行复杂的...
Java正则表达式是编程语言Java中用于处理字符串和文本的强大工具。它允许开发者通过模式匹配来执行复杂的文本分析和操作。在Java中,正则表达式的操作主要涉及两个核心类:`java.util.regex.Matcher`和`java.util....
Java正则表达式是Java编程语言中用于处理字符串的强大工具,它允许程序员通过模式匹配来查找、替换或分割文本。在Java中,正则表达式是通过`java.util.regex`包提供的API来实现的。本讲解将深入探讨Java正则表达式的...
Java正则表达式是编程语言中的一个重要组成部分,用于文本处理和模式匹配。Jakarta ORO(Oracle Regular Expressions for Java)是Apache软件基金会开发的一个强大的Java正则表达式库,它为开发者提供了更为灵活和...
Java正则表达式 Java 正则表达式 图片版 携带方便,查阅方便!~