UltraEdit正则表达式介绍及实例分享
前几天,有个将excel中的数据导入到数据库中的需求,原本想到用程序读取excel中的数据并存储到数据库中,但经一哥们的提醒,说用 editplus或ultraedit这样的工具直接将数据拼凑成sql插入语句更容易方便,也不用写任何代码,由于我本人使用ultraedit,故考 虑用ultraedit的正则表达式来做这件事,下面是这样的一个过程。
假设导入的表字段为:name,email, introduce,在excel中的数据对应的也是这样的字段,值得注意的是:在excel中的数据,比如introduce不能换行,不然的话语句拼凑后会执行会出错。
要拼凑的例子数据如下(从excel中拷贝并粘贴到ultraedit中):
张三 zhangsan@zihou.com "坐于2004年5月经教育部批准升格为普通本科院校。 " 李四 lisi@zihou.com 最专业的图文视频体育赛事直播、报道和‘专家'点评。
各字段值之间以一个或多个tab键分隔着,操作步骤:
替换按ctrl+r
1、 先将单引号、双引号之类的字符去掉,这一步不用正则,简单替换即可。
2、 去掉空行:用正则%[ ^t]++^p替换为空字符串,另外,还有^p$也可以,不过在替换的时候,^p$每次只能替换一个空行。
3、 在每行的最前面增加:insert into test(name,email,introduce)values(‘,在ultraedit正则中,%是表示行首,如下图:
4、 替换掉tab键
5、 最后在行尾加入’);
ok,大功告成!这样就拼凑成了正常的sql插入语句了,感觉是不是很快很容易?
如何学习ultraedit正则用法?可以通过以下两个方面:
1、 从网上搜些这方面的介绍资料
2、 通过ultraedit的帮助文档来进行学习
ultraedit的帮助文档有两方面,一方面是其chm格式的文档、另一方面是其官网的文档。
官网的文档进入方式为:菜单帮助->快速入门指南,在打开的窗口中,点击任一链接都会到其官网帮助文档页面,当然了,如果你到这里了,也可以直接点击下面的链接:
chm格式的文档进入方式为:
菜单帮助->使用帮助,或帮助->索引均可,如下图:
在左侧输入“正则表达式”进行查找,就会弹出右侧的窗口,看到有很多的使用介绍吧?你可以选择感兴趣的进去。
下面是从ultraedit文档中摘录的语法说明:
正则表达式 (ultraedit 语法):
符号 | 功能 |
% | 匹配行首 – 表示搜索字符串必须在行首,但不包括任何选定的结果字符中的行终止字符。 |
$ | 匹配行尾 – 表示搜索字符串必须在行尾,但不包括任何选定的结果字符中的行终止字符。 |
? | 匹配任何除换行符的字符。 |
* | 匹配任何除换行符外所出现的任意数量的字符。 |
+ | 匹配一个或多个前面的字符/表达式。必须找到至少一个出现的字符。不匹配重复的换行符。 |
++ | 0 次或多次匹配前面的字符/表达式。不匹配重复的换行符。 |
^b | 匹配一个分页符。 |
^p | 匹配一个换行符 (cr/lf) (段落) (dos 文件) |
^r | 匹配一个换行符 (仅 cr) (段落) (mac 文件) |
^n | 匹配一个换行符 (仅 lf) (段落) (unix 文件) |
^t | 匹配一个制表符 |
[ ] | 匹配任何括号中的单个字符或范围 |
^{a^}^{b^} | 匹配表达式 a 或 b |
^ | 忽略其后的正则表达式字符 |
^(*^) | 在表达式加上括号或标签在替换命令中使用。正则表达式中可以有 9 个表达式标签,数字根据它们在正则表达式中的次序确定数字。
相应的替换表达式是 ^x,x 的范围是 1-9。例如: 如果 ^(h*o^) ^(f*s^) 匹配“hello folks”,那么^2 ^1 表示将用“folks hello”替换它。 |
注意 – ^ 这里涉及的字符“^”不是控制键 + 值。
例如:
m?n 匹配“man”、“men”、“min”,但不匹配“moon”。
t*t 匹配“test”、“tonight”和“tea time”中的“tea t”部分,但不匹配“tea
time” (“tea ”和“time”之间有换行)。
te+st 匹配“test”、“teest”、“teeeest”等,但不匹配“tst”。
[aeiou] 匹配每个元音小写字母
[,.?] 匹配文字“,”、“.”或“?”。
[0-9a-z] 匹配任何数字或小写字母
[~0-9] 匹配除数字外的任何字符 (~ 表示不匹配其后的内容)
你可以搜索象下面一样的表达式 a 或 b:
“^{john^}^{tom^}
这将搜索 john 或 tom。在两个表达式之间应该没有任何其它内容。
你可以在同一次搜索象下面一样组合 a 或 b 和 c 或 d:
“^{john^}^{tom^} ^{smith^}^{jones^}”
这将搜索后面跟随了 smith 或 jones 的 john 或 tom。
下面的表显示“unix”样式的正则表达式语法。
正则表达式 (unix 语法):
符号 | 功能 |
\ | 表示下一个字符有特殊含义。“n”表示匹配字符“n”,“\n”匹配一换行符。看下面的例子 (\d、\f、\n 等)。 |
^ | 匹配/停驻行首。 |
$ | 匹配/停驻行尾。 |
* | 匹配前面的字符 0 次或多次。 |
+ | 匹配前面的字符一次或多次。不匹配重复的换行符。 |
. | 匹配任何除换行符之外的单个字符。不匹配重复的换行符。 |
(表达式) | 在表达式加上括号或标签在替换命令中使用。正则表达式中可以有 9 个表达式标签,数字根据它们在正则表达式中的次序确定数字。
相应的替换表达式是 ^x,x 的范围是 1-9。例如: 如果 ^(h*o^) ^(f*s^) 匹配“hello folks”,那么^2 ^1 表示将用“folks hello”替换它。 |
[xyz] | 字符集,匹配任何括号间的字符。. |
[^xyz] | 排除字符集。匹配任何不在括号间的字符。 |
\d | 匹配一个数字字符。等同于 [0-9]。 |
\d | 匹配一个非数字字符,等同于 [^0-9]。 |
\f | 匹配一个换页符。 |
\n | 匹配一个换行符。 |
\r | 匹配一个回车符。 |
\s | 匹配任何包含空格、制表符等不会显示的字符,但不匹配换行符。 |
\s | 匹配任何非空白区域 (显示字符) 的字符,但不匹配换行符。 |
\t | 匹配一个制表符。 |
\v | 匹配一个垂直制表符。 |
\w | 匹配任何包含下划线的词语。 |
\w | 匹配任何非词语的字符。 |
\p | 匹配 cr/lf (等同于 \r\n),用来匹配 dos 行终止符。 |
注意 – ^ 这里所涉及的字符“^”不是控制键 + 值。
例如:
m.n 匹配“man”、“men”、“min”,但不匹配“moon”。
te+st 匹配“test”、“teest”、“teeeest”等,但不匹配“tst”。
te*st 匹配“test”、“teest”、“teeeest”等,还有“tst”。
[aeiou] 匹配每个元音小写字母
[,.?] 匹配文字“,”、“.”或“?”。
[0-9a-z] 匹配任何数字或小写字母
[^0-9] 匹配除数字外的任何字符 (~ 表示不匹配其后的内容)
你可以象下面一样的表达式 a 或 b 进行搜索:
“(john|tom)”
这将搜索 john 或 tom。在两个表达式之间应该没有任何其它内容。
你可以在同一次搜索象下面一样组合 a 或 b 和 c 或 d:
“(john|tom) (smith|jones)”
这将搜索 smith 或 jones 以及跟随在后面的 john 或 tom。
如果在查找/替换中没有选择使用正则表达式,在替换对象中下列特殊字符同样有效:
符号 | 功能 |
^^ | 匹配字符“^” |
^s | 表示活动文件窗口中选定 (加亮) 的文字。 |
^c | 表示剪贴表的内容。 |
^b | 匹配一个分页符。 |
^p | 匹配一个换行符 (cr/lf) (段落) (dos 文件) |
^r | 匹配一个换行符 (仅 cr) (段落) (mac 文件) |
^n | 匹配一个换行符 (仅 lf) (段落) (unix 文件) |
^t | 匹配一个制表符 |
注意 – ^ 这里所涉及的字符“^”不是控制键 + 值。