欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

UltraEdit正則表達式介紹及實例分享

  發(fā)布時間:2012-10-28 20:34:24   作者:佚名   我要評論
下面是對UltraEdit的Help中針對查找替換使用正則表達式部分的整理,最后還有我前兩天用到的一個多行代碼查找替換的例子

前幾天,有個將Excel中的數(shù)據(jù)導入到數(shù)據(jù)庫中的需求,原本想到用程序讀取Excel中的數(shù)據(jù)并存儲到數(shù)據(jù)庫中,但經(jīng)一哥們的提醒,說用 EditPlus或UltraEdit這樣的工具直接將數(shù)據(jù)拼湊成SQL插入語句更容易方便,也不用寫任何代碼,由于我本人使用UltraEdit,故考 慮用UltraEdit的正則表達式來做這件事,下面是這樣的一個過程。

假設導入的表字段為:name,email, introduce,在Excel中的數(shù)據(jù)對應的也是這樣的字段,值得注意的是:在excel中的數(shù)據(jù),比如introduce不能換行,不然的話語句拼湊后會執(zhí)行會出錯。

要拼湊的例子數(shù)據(jù)如下(從Excel中拷貝并粘貼到UltraEdit中):

張三                            zhangsan@zihou.com              "坐于2004年5月經(jīng)教育部批準升格為普通本科院校。  "  李四                   lisi@zihou.com                           最專業(yè)的圖文視頻體育賽事直播、報道和‘專家'點評。 

各字段值之間以一個或多個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、  從網(wǎng)上搜些這方面的介紹資料

2、  通過UltraEdit的幫助文檔來進行學習

UltraEdit的幫助文檔有兩方面,一方面是其chm格式的文檔、另一方面是其官網(wǎng)的文檔。

官網(wǎng)的文檔進入方式為:菜單幫助->快速入門指南,在打開的窗口中,點擊任一鏈接都會到其官網(wǎng)幫助文檔頁面,當然了,如果你到這里了,也可以直接點擊下面的鏈接:

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

chm格式的文檔進入方式為:

菜單幫助->使用幫助,或幫助->索引均可,如下圖:

在左側(cè)輸入“正則表達式”進行查找,就會彈出右側(cè)的窗口,看到有很多的使用介紹吧?你可以選擇感興趣的進去。

下面是從UltraEdit文檔中摘錄的語法說明

正則表達式 (UltraEdit 語法):

符號 功能
% 匹配行首 – 表示搜索字符串必須在行首,但不包括任何選定的結(jié)果字符中的行終止字符。
$ 匹配行尾 – 表示搜索字符串必須在行尾,但不包括任何選定的結(jié)果字符中的行終止字符。
? 匹配任何除換行符的字符。
* 匹配任何除換行符外所出現(xiàn)的任意數(shù)量的字符。
+ 匹配一個或多個前面的字符/表達式。必須找到至少一個出現(xiàn)的字符。不匹配重復的換行符。
++ 0 次或多次匹配前面的字符/表達式。不匹配重復的換行符。
^b 匹配一個分頁符。
^p 匹配一個換行符 (CR/LF) (段落) (DOS 文件)
^r 匹配一個換行符 (僅 CR) (段落) (MAC 文件)
^n 匹配一個換行符 (僅 LF) (段落) (UNIX 文件)
^t 匹配一個制表符
[ ] 匹配任何括號中的單個字符或范圍
^{A^}^{B^} 匹配表達式 A 或 B
^ 忽略其后的正則表達式字符
^(*^) 在表達式加上括號或標簽在替換命令中使用。正則表達式中可以有 9 個表達式標簽,數(shù)字根據(jù)它們在正則表達式中的次序確定數(shù)字。

相應的替換表達式是 ^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] 匹配任何數(shù)字或小寫字母

[~0-9] 匹配除數(shù)字外的任何字符 (~ 表示不匹配其后的內(nèi)容)

你可以搜索象下面一樣的表達式 A 或 B:

“^{John^}^{Tom^}

這將搜索 John 或 Tom。在兩個表達式之間應該沒有任何其它內(nèi)容。

你可以在同一次搜索象下面一樣組合 A 或 B 和 C 或 D:

“^{John^}^{Tom^} ^{Smith^}^{Jones^}”

這將搜索后面跟隨了 Smith 或 Jones 的 John 或 Tom。

下面的表顯示“Unix”樣式的正則表達式語法。

正則表達式 (Unix 語法):

符號 功能
\ 表示下一個字符有特殊含義。“n”表示匹配字符“n”,“\n”匹配一換行符??聪旅娴睦?(\d、\f、\n 等)。
^ 匹配/停駐行首。
$ 匹配/停駐行尾。
* 匹配前面的字符 0 次或多次。
+ 匹配前面的字符一次或多次。不匹配重復的換行符。
. 匹配任何除換行符之外的單個字符。不匹配重復的換行符。
(表達式) 在表達式加上括號或標簽在替換命令中使用。正則表達式中可以有 9 個表達式標簽,數(shù)字根據(jù)它們在正則表達式中的次序確定數(shù)字。

相應的替換表達式是 ^x,x 的范圍是 1-9。例如: 如果 ^(h*o^) ^(f*s^) 匹配“hello folks”,那么^2 ^1 表示將用“folks hello”替換它。

[xyz] 字符集,匹配任何括號間的字符。.
[^xyz] 排除字符集。匹配任何不在括號間的字符。
\d 匹配一個數(shù)字字符。等同于 [0-9]。
\D 匹配一個非數(shù)字字符,等同于 [^0-9]。
\f 匹配一個換頁符。
\n 匹配一個換行符。
\r 匹配一個回車符。
\s 匹配任何包含空格、制表符等不會顯示的字符,但不匹配換行符。
\S 匹配任何非空白區(qū)域 (顯示字符) 的字符,但不匹配換行符。
\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] 匹配任何數(shù)字或小寫字母

[^0-9] 匹配除數(shù)字外的任何字符 (~ 表示不匹配其后的內(nèi)容)

你可以象下面一樣的表達式 A 或 B 進行搜索:

“(John|Tom)”

這將搜索 John 或 Tom。在兩個表達式之間應該沒有任何其它內(nèi)容。

你可以在同一次搜索象下面一樣組合 A 或 B 和 C 或 D:

“(John|Tom) (Smith|Jones)”

這將搜索 Smith 或 Jones 以及跟隨在后面的 John 或 Tom。

如果在查找/替換中沒有選擇使用正則表達式,在替換對象中下列特殊字符同樣有效:

符號 功能
^^ 匹配字符“^”
^s 表示活動文件窗口中選定 (加亮) 的文字。
^c 表示剪貼表的內(nèi)容。
^b 匹配一個分頁符。
^p 匹配一個換行符 (CR/LF) (段落) (DOS 文件)
^r 匹配一個換行符 (僅 CR) (段落) (MAC 文件)
^n 匹配一個換行符 (僅 LF) (段落) (UNIX 文件)
^t 匹配一個制表符

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

相關文章

  • 解決UltraEdit在UTF-8編碼下的亂碼問題

    最近寫幾個自定義的xml配置文件,開頭如此:,結(jié)果保存后的文件再使用UE打開時中文內(nèi)容便成了亂碼,甚是郁悶
    2012-03-12
  • UltraEdit+刪除空行的正則表達式

    用UltraEdit+正則表達式刪除空行的方法,需要的朋友可以參考下。
    2011-01-03
  • UltraEdit技巧總結(jié)

    查找操作 1.ctrl+b 寫程序的時候,括號一般要一一對應的,但是如果嵌套太多,看花眼了,怎么辦?你把光標放在括號開始的地方,按ctrl+b,UE 會幫你找到相對應的括號結(jié)尾的
    2009-08-27
  • 在UltraEdit中使用正則表達式

    很多朋友都用過或者正在用UltraEdit,這個編輯器陪伴我也好幾年了,從很多地方影響著我寫代碼的快捷鍵習慣,Ultraedit提供了非常豐富的編輯功能,其中非常重要的查找和替換
    2012-10-28
  • UltraEdit高級使用技巧分享

    UltraEdit是眾多IDE中頗有亮點的一款,它功能強大,這里說一下它的一些很好用的功能
    2012-05-03
  • UltraEdit使用技巧之常用快捷鍵大全

    UltraEdit是一套功能強大的文本編輯器,可以編輯文本、十六進制、ASCII碼,可以取代記事本等等,功能很多,下面我們來看看UltraEdit常用快捷鍵有哪些
    2014-10-24
  • ue編輯器怎么用?ultraedit文本編輯器使用方法

    ue編輯器怎么用?想知道的朋友就和小編一起來看看ultraedit文本編輯器使用方法吧
    2014-10-24

最新評論