UltraEdit风格正则表达式语法@H_404_7@
1、%@H_404_7@
功能说明: 匹配一行的开始位置。这个符号表示所寻找的字符在每一行的开始的位置,不包括每一行其上一行的结束字符。@H_404_7@
2、$@H_404_7@
功能说明:匹配一行的结束位置。这个符号表示所寻找的字符在每一行的结束的位置。这个$和上面说的“行头”恰恰相反,它是“行尾”。@H_404_7@
3、?@H_404_7@
功能说明:匹配每一个字符,除了“换行符”以外。@H_404_7@
4、*@H_404_7@
功能说明:匹配任意个数的任何字符,除了“换行符”以外。@H_404_7@
5、+@H_404_7@
功能说明:匹配一个或多个所提到的字符或是表达式,至少要出现一次。不匹配重复的“换行符”。@H_404_7@
6、++@H_404_7@
功能说明:匹配零次或是很多次所提到的字符或表达式,不匹配重复的“换行符”。@H_404_7@
7、^b@H_404_7@
8、^p@H_404_7@
9、^r@H_404_7@
10、^n@H_404_7@
11、^t@H_404_7@
12、[ ]@H_404_7@
功能说明:匹配在方括号里面的任何单个字符,可以用范围来表示。@H_404_7@
13、^{A^}^{B^}@H_404_7@
14、^@H_404_7@
注意:现在使用当中也可以表示指定行的开头。@H_404_7@
15、^(…^)@H_404_7@
功能说明: 匹配第1个到第9个指定的表达式,并且可以用其序号来变换位置@H_404_7@
例如:“hello world”满足表达式“^(h*o^) ^(w*d^)”,而表达式“^2 ^1”就可以把“hello world”替换为“world hello”。@H_404_7@
下面我举一些很简单的例子,让大家看看:@H_404_7@
m?n 匹配“man”,“men”,“min”但是不能匹配“moon”。@H_404_7@
t*t匹配“test”,“tonight”和“tea time”但是不能匹配“tea time”(换行符在“tea ”和“time”之间)。@H_404_7@
Te+st匹配“test”,“teest”,“teeeest”等等,但是不能匹配“tst”。@H_404_7@
[aeIoU] 匹配任一个属于aeIoU的字母@H_404_7@
[,。?]匹配“,”、“。”和“?”中的任意一个@H_404_7@
[0-9a-z] 匹配任何一个1-9的数字a到z的小写字母@H_404_7@
[~0-9] 匹配任何一个字符除了数字以外(~符号的意思是表示“非”)@H_404_7@
这里只介绍了UE中“传统正则表达式”的语法,很简单几个,但是它们却能满足您批量文本处理的要求。如能活用,那更是其乐无穷,让你体会到电脑给工作带来的魅力。@H_404_7@
小知识: 正则表达式英文REGULAR EXPRESSIONS,其精髓就是两个字――“统配”。在文本编辑软件中用途之广,“变体”之多,都足以证明其地位。现在的ULTRAEDIT版本中除 了传统的正则表达式和UNIX风格的正则表达式以外还加入了与PERL兼容的正则表达式语法,可以说使ULTRAEDIT更加完美。@H_404_7@
UltraEdit的正则表达式功能很有用,转贴两篇文章:@H_404_7@
删除空行: 替换 %[ ^t]++^p 为 空串@H_404_7@
删除行尾空格: 替换 [ ^t]+$ 为 空串@H_404_7@
删除行首空格: 替换 %[ ^t]+ 为 空串@H_404_7@
每行设置为固定的4个空格开头: 替换 %[ ^t]++^([~ ^t^p]^) 为 " ^1"@H_404_7@
每段设置为固定的4个空格开头: 替换 %[ ^t]+ 为 " "@H_404_7@
(如果一行是以空格开始的,则视之为一段的开始行)@H_404_7@
将一段合并为一行: 替换 [ ^t]++^p^([~ ^t^p]^) 为 ^1@H_404_7@
(注意: 此处假定文本是以DOS方式回车换行 - CR/LF)@H_404_7@
去掉HTML TAG: 替换 ^{<*>^}^{<*^p*>^} 为 空串@H_404_7@
删除HTML中的所有<A>: 替换 <[ ]++a *[ ]++href[ ]++=*> 为 空串@H_404_7@
删除文本中指定的前2列字符: 替换 %?? 为 空串@H_404_7@
在第4列后插入2列空白字符: 替换 %^(????^)^(?^) 为 "^1 ^2"@H_404_7@
查找所有的数字: [0-9]+[.]++[0-9]+@H_404_7@
查找所有的单词: [a-z]+@H_404_7@
查找所有的网址: http://[a-z0-9^~`_./^-^?=&]+@H_404_7@
一个正则表达式最多可以有9个标注表达式,按正规表达式的需要而定。@H_404_7@
相应的替换表达式是 ^x,替换范围x是1-9。例如:@H_404_7@
If ^(h*o^) ^(f*s^) matches "hello folks",@H_404_7@
^2 ^1 would replace it with "folks hello".@H_404_7@
(hello folks 将被替换成 folks hello。)@H_404_7@
注: ^ 是实际字符 ^不是Ctl + 键值。@H_404_7@
@H_404_7@
-------------------------->>
下面演示一下在UltraEdit中如何使用正则表达式(通配符)进行常用的查找和替换。@H_404_7@
准备工作:在使用正则表达式前,先需要进行一些设置。@H_404_7@
1. 高级 -> 配置 -> 搜索 -> 正则表达式引擎,勾选UltraEidt风格正则表达式@H_404_7@
2. 在查找及替换框中,均需勾选“正则表达式”。@H_404_7@
@H_404_7@
【2012-01-29T00:00:09】【N】: ****************************************@H_404_7@
#### total packets num 5584921854
#### total un-packets num 4645790779
@@@@ unpack rate: 1.29598/s
[API_FH_0] packets left: 0
[API_FH_1] packets left: 0
[API_FH_2] packets left: 0
[API_FH_3] packets left: 0
[API_FH_4] packets left: 0
[API_FH_5] packets left: 0
[API_SS_0] packets left: 0
[API_SS_1] packets left: 0
[API_SS_2] packets left: 0
[API_SS_3] packets left: 0
[API_SS_4] packets left: 0
[API_S_5] packets left: 0
FH Unpack rate: 100%
SS Unpack rate: 100%
Mem: 290.8 MB,Virtual Mem: 429.8 MB,Total: 720.6 MB.
@H_404_7@
@H_404_7@
一.正则表达式查找@H_404_7@
“*”代表匹配任意长度的字符,“?”代表匹配一个长度的字符。@H_404_7@
若进行如下输入@H_404_7@
@H_404_7@
@H_404_7@
@H_404_7@
若输入:@H_404_7@
@H_404_7@
@H_404_7@
@H_404_7@
二.正则表达式替换
@H_404_7@
替换的统配符采用的是UltraEdit风格通配符,因此格式上与查找通配符有些不同。@H_404_7@
“^(*^)”代表替换时匹配任意长度字符,“^(?^)”代表替换时匹配一个长度的字符。
@H_404_7@
例如,若输入如下:@H_404_7@
@H_404_7@
@H_404_7@
若输入如下:@H_404_7@
@H_404_7@