轉載,原文地址如下
http://tanqisen.github.io/blog/2013/01/13/vim-search-replace-regex/
簡單替換表達式
:[range]s/from/to/[flags]
-
range
:搜索范圍,如果沒有指定范圍,則作用於但前行。:1,10s/from/to/
表示在第1到第10行(包含第1,第10行)之間搜索替換;:10s/from/to/
表示只在第10行搜索替換;:%s/from/to/
表示在所有行中搜索替換;1,$s/from/to/
同上。
-
flags
有如下四個選項:c
confirm,每次替換前詢問;e
error, 不顯示錯誤;g
globle,不詢問,整行替換。如果不加g
選項,則只替換每行的第一個匹配到的字符串;i
ignore,忽略大小寫。
這些選項可以合並使用,如
cgi
表示不區分大小寫,整行替換,替換前詢問。
正則表達式
-
元字符
-
元字符
元字符 說明 . 匹配任意字符 [abc] 匹配方括號中的任意一個字符,可用 -
表示字符范圍。如[a-z0-9]匹配小寫字母和數字[^abc] 匹配除方括號中字符之外的任意字符 \d 匹配阿拉伯數字,等同於[0-9] \D 匹配阿拉伯數字之外的任意字符,等同於[^0-9] \x 匹配十六進制數字,等同於[0-9A-Fa-f] \X 匹配十六進制數字之外的任意字符,等同於[^0-9A-Fa-f] \l 匹配[a-z] \L 匹配[^a-z] \u 匹配[A-Z] \U 匹配[^A-Z] \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個 -
表示位置的元字符
元字符 說明 $ 匹配行尾 ^ 匹配行首 \< 匹配單詞詞首 \> 匹配單詞詞尾
-
-
替換變量
在正則式中以
\(
和\)
括起來的正則表達式,在后面使用的時候可以用\1
、\2
等變量來訪問\(
和\)
中的內容。
例子
- 刪除行尾空格:
:%s/\s+$//g
- 刪除行首多余空格:
%s/^\s*//
或者%s/^ *//
- 刪除沒有內容的空行:
%s/^$//
或者g/^$/d
- 刪除包含有空格組成的空行:
%s/^\s*$//
或者g/^\s*$/d
- 刪除以空格或TAB開頭到結尾的空行:
%s/^[ |\t]*$//
或者g/^[ |\t]*$/d
-
把文中的所有字符串“abc……xyz”替換為“xyz……abc”可以有下列寫法
:%s/abc\(.*\)xyz/xyz\1abc/g :%s/\(abc\)\(.*\)\(xyz\)/\3\2\1/g
sed:指定文件進行替換
sed -i "s/from/to/g" 文件名