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格式的文档、另一方面是其官网的文档。

官网的文档进入方式为:菜单帮助->快速入门指南,在打开的窗口中,点击任一链接都会到其官网帮助文档页面,当然了,如果你到这里了,也可以直接点击下面的链接:

http://www.ultraedit.com/support/tutorials_power_tips/ultraedit.html

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 匹配一个制表符

注意 – ^ 这里所涉及的字符“^”不是控制键 + 值。

(0)

相关推荐

  • 《侠盗飞车罪恶都市》游戏基础介绍与视频分享

    <侠盗飞车罪恶都市>游戏基础介绍与视频分享PC版<侠盗猎车手:罪恶都市>(Grand Theft Auto: Vice City,后文简称VC)这款游戏在许多方面都要好于其前作 ...

  • Editplus常用正则表达式介绍

    正则表达式类 【1】 正则表达式应用——替换指定内容到行尾 【2】 正则表达式应用——数字替换—————————-Microshaoft@CCF,jiuk2k@CCF 【3】 正则表达式应用——删除每 ...

  • Linux的命令行中一些文本操作技巧的实例分享

    正则表达式 翻译领域不乏让人摸不着头脑的词汇,比如"句柄"."套接字"."鲁棒性".当然,"正则表达式"也属于这一类词汇 ...

  • linux系统find命令之xargs使用实例分享

    错误信息通常是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一起使用。 find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是 ...

  • linux学习日记九 正则表达式介绍

    正则表达式就是处理字符串的方法,它以行为单位来进行字符串的处理行为,正则表达式通过一些特殊符号的辅助,可以让用户轻易达到查找、删除、替换某特定字符串的处理程序。 正则表达式基本上就是一种“表示法”,只 ...

  • linux配置防火墙iptables实例分享

    iptables一个详细实例 复制代码 代码如下: /etc/init.d/iptables start 启动iptables 初始化iptables,删除之前的规则, 复制代码 代码如下: ipta ...

  • WPS表格日期与时间函数的详细介绍和实例教程

    (一)日期与时间函数1.DATE用途:返回代表特定日期的序列号。 语法:DATE(年,月,日) 参数:年, 为一到四位,根据使用的日期系统解释该参数。默认情况下,wps表格使用1900 日期系统。月, ...

  • linux下的删除重复行命令uniq详细介绍和实例

    一,uniq干什么用的 文本中的重复行,基本上不是我们所要的,所以就要去除掉。linux下有其他命令可以去除重复行,但是我觉得uniq还是比较方便的一个。使用uniq的时候要注意以下二点 1,对文本操 ...

  • 硬盘分区不见了后成功恢复数据实例分享

    前几天,我自己用U盘重装系统,以前都是选择一键装机,很简单.这次尝试手动安装,结果设置错误,导致整个硬盘变成了一整个分区,原来的分区找不到了,整个硬盘数据无法读取.因为电脑里有重要资料,自然不舍得格式 ...