gvim正則表達式常在命令行模式下使用,一般用于文本文件字符串的替換、刪除等操作。
典型的替換命令格式:
%s/正則表達式/要替換的字符串/g”
典型刪除命令格式:
%g/正則表達式/d
我們先講元字符,接著講述一些基本的應用例子,最后講一些更高階的應用例子,一文搞懂正則表達式!
一. 元字符
先搞清幾個基本的概念,普通元字符,特殊元字符,數量元字符,位置元字符。
1. 普通元字符:
通常用來表示數字、單詞、空格等。
[abc] | 匹配a,b,c任意字符 |
[^abc] | 匹配除abc以外的字符 |
d | 匹配阿拉伯數字,等同于[0~9],decimal十進制 |
D | 匹配阿拉伯數字之外的任意字符,等同于[^0~9] |
x | 匹配十六進制數字,等同于[0-9A-Fa-f],heximal十六進制 |
X | 匹配十六進制數字之外的任意字符,等同于[^0-9A-Fa-f] |
w | 匹配單詞字母,等同于[0-9A-Za-z],正則表達式中一般用"w+"表示一個單詞 |
W | 匹配單詞字母之外的任意字符,等同于[0-9A-Za-z] |
s | 匹配空白符,等同于[ ] |
t? | 匹配Tab字符 |
. | 匹配任意字符 |
2. 特殊字符:
特殊字符通常用來表示一些特殊的符號,用轉義。
* | 匹配 * 字符 |
. | 匹配 . 字符 |
/ | 匹配 / 字符 |
匹配 字符 | |
[ | 匹配 [ 字符 |
3. 數量元字符:
通常用來表示普通字符(數字、單詞、空格)的數量。
* | 匹配0~任意個 |
+ | 匹配1~任意個 |
? | 匹配0~1個 |
{n,m} | 匹配n ~ m個 |
{n} | 匹配 n個 |
{n,} | 匹配 n ~ 任意個 |
{,m} | 匹配 0 ~ m 個 |
4. 位置元字符
$ | 匹配行尾 |
v | 匹配行首 |
< | 匹配單詞詞首 |
> | 匹配單詞詞尾 |
幾個例子:
[abc]表示匹配 a,b,c中的任意一個字符;
abc表示匹配abc,abc為一個整體;
[^abc]表示匹配除 a,b,c 以外的任意任意字符
^abc表示匹配以abc為開頭的字符串,abc為一整體
w+表示匹配任意單詞
二. 基礎應用
替換與刪除示例:
1. 把所有的abc或者Abc都替換為大寫的ABC;
命令: %s/[Aa]bc/ABC/g
2. 刪除所有空行(空行中無任何字符)
命令: %g/ ^ $/d
3.刪除所有空行(空行中可以包含空白符、Tab鍵等)
命令:%g/^ s * $/d
4. 刪除含有abc字符的行
命令1: g/abc/d
命令2: %s/.*abc. *$//g (替換命令實現刪除)
5. 刪除每行開頭的空格
命令 :%s/^ *//g——通過替換命令實現刪除效果
6. 在文件中的每一行的開始插入abc字符
命令 ——:%s/^/abc/g
7. 在每一行尾部都加上abc字符
命令: %s/$/abc/g
8. 刪除以數字開頭的行
命令: %s/^d . *$ //g
三. 高階應用-分組
所謂分組,即使用 ( 和 )符號括起來的正則表達式,即可在其后面使用1 ,2等變量來訪問 ( 和 )符號括起來的內容。
1.交換順序:ABC:XYZ改為XYZ:ABC
命令:%s/ (. ):(. )/2:1/g
2.abc開頭的后面為一個或多個空格,然后為一個單詞,將abc和該單詞交換位置
命令: %s/^(abc)s+ (w+) /2 1/g
3.刪除重復行
命令 :%s/^ (.*)( 1){2,}/1/g (將2行及以上重復行壓縮成一行)
解釋:^(. * )表示以任意字符開頭的行, 表示換行符, ( 1){2,}表示^(.* )換行后重復2次以上,替換成一行。
4. 給各行開頭加上行號+: (123: )
命令: %s/^/=line('.').':'
解釋:^代表行首,line('.')代表獲取行號的函數,.':'代表拼接:號,最終格式為:"行號:"。
審核編輯:劉清
-
Gvim
+關注
關注
0文章
8瀏覽量
2962
原文標題:你還不會gvim正則表達式???來,一文搞懂!
文章出處:【微信號:處芯積律,微信公眾號:處芯積律】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論