標籤:style blog http 使用 strong ar div log sp
來自:http://blog.csdn.net/endall/archive/2007/08/29/1764554.aspx
Vim中的Regex功能很強大,如果能自由運用,則可以完成很多難以想象的操作。
如果你比較熟悉Perl的正規運算式,可以直接參照與PerlRegex的區別一節。
使用Regex的命令
使用Regex的命令最常見的就是 / (搜尋)命令。其格式如下:
/Regex
另一個很有用的命令就是 :s(替換)命令,將第一個//之間的Regex替換成第二個//之間的字串。
:s/Regex/替換字串/選項
在學習Regex時可以利用 / 命令來練習。
元字元
元字元是具有特殊意義的字元。使用元字元可以表達任一字元、行首、行尾、某幾個字元等意義。
元字元一覽
元字元 |
說明 |
. |
匹配任意一個字元 |
[abc] |
匹配方括弧中的任意一個字元。可以使用-表示字元範圍, 如[a-z0-9]匹配小寫字母和阿拉伯數字。 |
[^abc] |
在方括弧內開頭使用^符號,表示匹配除方括弧中字元之外的任一字元。 |
\d |
匹配阿拉伯數字,等同於[0-9]。 |
\D |
匹配阿拉伯數字之外的任一字元,等同於[^0-9]。 |
\x |
匹配十六進位數字,等同於[0-9A-Fa-f]。 |
\X |
匹配十六進位數字,等同於[^0-9A-Fa-f]。 |
\w |
匹配單詞字母,等同於[0-9A-Za-z_]。 |
\W |
匹配單詞字母之外的任一字元,等同於[^0-9A-Za-z_]。 |
\t |
匹配<TAB>字元。 |
\s |
匹配空白字元,等同於[ \t]。 |
\S |
匹配非空白字元,等同於[^ \t]。 |
另外,如果要尋找字元 *、.、/等,則需要在前面用 \ 符號,表示這不是元字元,而只是一般字元而已。
元字元 |
說明 |
\* |
匹配 * 字元。 |
\. |
匹配 . 字元。 |
\/ |
匹配 / 字元。 |
\\ |
匹配 \ 字元。 |
\[ |
匹配 [ 字元。 |
↑表示數量的元字元 †
元字元 |
說明 |
* |
匹配0-任意個 |
\+ |
匹配1-任意個 |
\? |
匹配0-1個 |
\{n,m} |
匹配n-m個 |
\{n} |
匹配n個 |
\{n,} |
匹配n-任意個 |
\{,m} |
匹配0-m個 |
↑表示位置的符號 †
元字元 |
說明 |
$ |
匹配行尾 |
^ |
匹配行首 |
\< |
匹配單詞詞首 |
\> |
匹配單詞詞尾 |
使用例
/char\s\+[A-Za-z_]\w*; " 尋找所有以char開頭,之後是一個以上的空白, " 最後是一個標識符和分號/\d\d:\d\d:\d\d " 尋找如 17:37:01 格式的時間字串:g/^\s*$/d " 刪除只有空白的行:s/\<four\>/4/g " 將所有的four替換成4,但是fourteen中的four不替換
↑替換變數 †
在正規運算式中使用 \( 和 \) 符號括起正規運算式,即可在後面使用\1、\2等變數來訪問 \( 和 \) 中的內容。
使用例
/\(a\+\)[^a]\+\1 " 尋找開頭和結尾處a的個數相同的字串, " 如 aabbbaa,aaacccaaa,但是不匹配 abbbaa:s/\(http:\/\/[-a-z\._~\+%\/]\+\)/<a href="\1">\1<\/a>/ " 將URL替換為<a href="http://url">http://url</a>的格式:s/\(\w\+\)\s\+\(\w\+\)/\2\t\1 " 將 data1 data2 修改為 data2 data1
↑函數式 †
在替換命令 s/// 中可以使用函數運算式來書寫替換內容,格式為
:s/替換字串/\=函數式
在函數式中可以使用 submatch(1)、submatch(2) 等來引用 \1、\2 等的內容,而submatch(0)可以引用匹配的整個內容。
使用例
:%s/\<id\>/\=line(".") " 將各行的 id 字串替換為行號:%s/^\<\w\+\>/\=(line(".")-10) .".". submatch(1) " 將每行開頭的單詞替換為 (行號-10).單詞 的格式, " 如第11行的 word 替換成 1. word
↑與PerlRegex的區別 †
元字元的區別
Vim文法 |
Perl文法 |
含義 |
\+ |
+ |
1-任意個 |
\? |
? |
0-1個 |
\{n,m} |
{n,m} |
n-m個 |
\(和\) |
(和) |
分組 |
Vim中的Regex[轉]