业务场景:将 mybatis 对应的 xml 中数据库表名以及表的字段名修改为小写。
开发工具:intellij idea
思考:
如果仅仅是替换单个字段,选中该字段,使用快捷键 ctrl + alt +u 即可。当文本中出现该字段多次,ctrl + r 循环查找替换即可。如果要替换的字段多且不确定,我希望它能够具有一定规律。
实践:
我的目的很简单,其实就是将符合条件的大写单词转换为小写。首先我要做两件事,一个是查找,查找的字符串具有一定规律,很明显使用正则。第二是替换,将原字符串转换为小写。我查找到使用下面的命令就可以实现:
(w+)
L$1
其中,w+是匹配字符串的正则,L$1是将匹配到的字符串替换为小写。很明显,正则在实际场景中可能并不符合我的要求,我需要自行修改一下。
例如匹配 类似于 T.DATA_TYPE 这样的字符串
([A-Z]{1}.[A-Z]+\_?[A-Z]+)
例如匹配 类似于 t1.ORG_PERS_VISIBLE 这样的字符串
([w]{1}[d].[A-Z]+\_?[w]+)
例如匹配 类似于 P.PERMI_ID 这样的字符串
([a-zA-Z]+.[A-Z]{2,}+\_?[w]+)
例如匹配 类似于 ROLE_CODE AS 这样的字符串
([A-Z]{2,}\_?[w]+s[Aa][Ss])
大概就这样,我完成了我的需求。
备注:
-
U
将匹配项转为大写(Upper) -
L
将匹配项转为小写(Lower)
常用元字符
代码 | 说明 |
---|---|
. | 匹配除换行符以外的任意字符 |
w | 匹配字母或数字或下划线 |
s | 匹配任意的空白符 |
d | 匹配数字 |
匹配单词的开始或结束 | |
^ | 匹配字符串的开始 |
$ | 匹配字符串的结束 |
常用限定符
代码/语法 | 说明 |
---|---|
* | 重复零次或更多次 |
+ | 重复一次或更多次 |
? | 重复零次或一次 |
{n} | 重复n次 |
{n,} | 重复n次或更多次 |
{n,m} | 重复n到m次 |
常用反义词
代码/语法 | 说明 |
---|---|
W | 匹配任意不是字母,数字,下划线,汉字的字符 |
S | 匹配任意不是空白符的字符 |
D | 匹配任意非数字的字符 |
B | 匹配不是单词开头或结束的位置 |
[^x] | 匹配除了x以外的任意字符 |
[^aeiou] | 匹配除了aeiou这几个字母以外的任意字符 |
最后修改于 2020年5月3日 21:35:11