Vim特定行行尾追加
python print 替換 logging
1、print語(yǔ)句最后追加")"。
:%s/\(.*\)print \(.*\)/\1print \2)/g
2、" ??? print "替換“l(fā)ogger.info(”
:%s/\(.*\)print \(.*\)/\1print \2)/g
?
--------------------------------------------------------------------------------
轉(zhuǎn)載地址:http://www.cnblogs.com/PegasusWang/p/3153300.html
Vim中的正則表達(dá)式功能很強(qiáng)大,如果能自由運(yùn)用,則可以完成很多難以想象的操作。
如果你比較熟悉Perl的正規(guī)表達(dá)式,可以直接參照與Perl正則表達(dá)式的區(qū)別一節(jié)。
一、使用正則表達(dá)式的命令
使用正則表達(dá)式的命令最常見(jiàn)的就是?/ (搜索)命令。其格式如下:
/正則表達(dá)式另一個(gè)很有用的命令就是?:s(替換)命令,將第一個(gè)//之間的正則表達(dá)式替換成第二個(gè)//之間的字符串。
:s/正則表達(dá)式/替換字符串/選項(xiàng)在學(xué)習(xí)正則表達(dá)式時(shí)可以利用?/?命令來(lái)練習(xí)。
二、元字符
元字符是具有特殊意義的字符。使用元字符可以表達(dá)任意字符、行首、行 尾、某幾個(gè)字符等意義。
元字符一覽
| 元字符 | 說(shuō)明 |
| . | 匹配任意一個(gè)字符 |
| [abc] | 匹配方括號(hào)中的任意一個(gè)字符。可以使用-表示字符范圍, 如[a-z0-9]匹 配小寫(xiě)字母和阿拉伯?dāng)?shù)字。 |
| [^abc] | 在方括號(hào)內(nèi)開(kāi)頭使用^符號(hào),表示匹配除方括號(hào)中字符之外的任意字符。 |
| \d | 匹配阿拉伯?dāng)?shù)字,等同于[0-9]。 |
| \D | 匹配阿拉伯?dāng)?shù)字之外的任意字符,等同于[^0-9]。 |
| \x | 匹配十六進(jìn)制數(shù)字,等同于[0-9A-Fa-f]。 |
| \X | 匹配十六進(jìn)制數(shù)字之外的任意字符,等同于[^0-9A-Fa-f]。 |
| \w | 匹配單詞字母,等同于[0-9A-Za-z_]。 |
| \W | 匹配單詞字母之外的任意字符,等同于[^0-9A-Za-z_]。 |
| \t | 匹配<TAB>字符。 |
| \s | 匹配空白字符,等同于[ \t]。 |
| \S | 匹配非空白字符,等同于[^ \t]。 |
另外,如果要查找字符 *、.、/等,則需要在前面用?\?符號(hào),表示這不是元字符,而只是普通字符而已。
| 元字符 | 說(shuō)明 |
| \* | 匹配 * 字符。 |
| \. | 匹配 . 字符。 |
| \/ | 匹配 / 字符。 |
| \\ | 匹配 \ 字符。 |
| \[ | 匹配 [ 字符。 |
表示數(shù)量的元字符
| 元字符 | 說(shuō)明 |
| * | 匹配0-任意個(gè) |
| \+ | 匹配1-任意個(gè) |
| \? | 匹配0-1個(gè) |
| \{n,m} | 匹配n-m個(gè) |
| \{n} | 匹配n個(gè) |
| \{n,} | 匹配n-任意個(gè) |
| \{,m} | 匹配0-m個(gè) |
表示位置的符號(hào)
| 元字符 | 說(shuō)明 |
| $ | 匹配行尾 |
| ^ | 匹配行首 |
| \< | 匹配單詞詞首 |
| \> | 匹配單詞詞尾 |
使用例
/char\s\+[A-Za-z_]\w*; " 查找所有以char開(kāi)頭,之后是一個(gè)以上的空白," 最后是一個(gè)標(biāo)識(shí)符和分號(hào)
/\d\d:\d\d:\d\d " 查找如 17:37:01 格式的時(shí)間字符串
:g/^\s*$/d " 刪除只有空白的行
:s/\<four\>/4/g " 將所有的four替換成4,但是fourteen中的four不替換
三、替換變量
在正規(guī)表達(dá)式中使用?\(?和?\)?符號(hào)括起正規(guī)表達(dá)式,即可在后面使用\1、\2?等變量來(lái)訪(fǎng)問(wèn)?\(?和?\)?中的內(nèi)容。
使用例
/\(a\+\)[^a]\+\1 " 查找開(kāi)頭和結(jié)尾處a的個(gè)數(shù)相同的字符串," 如 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
四、函數(shù)式
在替換命令?s///?中可以使用函數(shù)表達(dá)式來(lái)書(shū)寫(xiě)替換內(nèi)容,格式為
:s/替換字符串/\=函數(shù)式在函數(shù)式中可以使用 submatch(1)、submatch(2) 等來(lái)引用?\1、\2?等的內(nèi)容,而submatch(0)可以引用匹配的整個(gè)內(nèi)容。
使用例
:%s/\<id\>/\=line(".") " 將各行的 id 字符串替換為行號(hào):%s/^\<\w\+\>/\=(line(".")-10) .".". submatch(1) " 將每行開(kāi)頭的單詞替換為 (行號(hào)-10).單詞 的格式,
" 如第11行的 word 替換成 1. word
五、與Perl正則表達(dá)式的區(qū)別
元字符的區(qū)別
| Vim語(yǔ)法 | Perl語(yǔ)法 | 含義 |
| \+ | + | 1-任意個(gè) |
| \? | ? | 0-1個(gè) |
| \{n,m} | {n,m} | n-m個(gè) |
| \(和\) | (和) | 分組 |
六、vi 正則表達(dá)式練習(xí)
?
閑言碎語(yǔ)不要講…例子說(shuō)明一切,比如下面這段我需要換成 ubb 標(biāo)簽
?
?
vim 命令模式,輸入
:%s/.*src=”([^"]*)”[^>]*>/[img]1[/img]/g
替換為
[img ]gu.jpg[ /img]
[img ]os.jpg[ /img]
[img ]hu.jpg[ /img]
[img ]ang.jpg[ /img]
解釋如下:
:
命令執(zhí)行狀態(tài)
%s
表示查找并替換
%s/a/b/g
a?被查找的字符串(正則匹配);b?要替換成的文字;g?表示全局搜索替換(否則只處理找到的第一個(gè)結(jié)果)
([^"]*)
表示非引號(hào)的字符N個(gè);外面?()?表示后面替換要用(用 1,…,9等引用)
[/img]
/ 需要被 轉(zhuǎn)義
與其它工具正則不一樣的地方在于 () 也必須 (),怪不得我老是弄不出來(lái)。
相關(guān)資料:
via?http://net.pku.edu.cn/~yhf/tao_regexps_zh.html
vi 命令 作用
:%s/ */ /g 把一個(gè)或者多個(gè)空格替換為一個(gè)空格。
:%s/ *$// 去掉行尾的所有空格。
:%s/^/ / 在每一行頭上加入一個(gè)空格。
:%s/^[0-9][0-9]* // 去掉行首的所有數(shù)字字符。
:%s/b[aeio]g/bug/g 將所有的bag、beg、big和bog改為bug。
:%s/t([aou])g/h1t/g 將所有tag、tog和tug分別改為hat、hot和hug(注意用group的用法和使用1引用前面被匹配的字符)。
Sed
Sed是Stream EDitor的縮寫(xiě),是Unix下常用的基于文件和管道的編輯工具,可以在手冊(cè)中得到關(guān)于sed的詳細(xì)信息。
這里是一些有趣的sed腳本,假定我們正在處理一個(gè)叫做price.txt的文件。注意這些編輯并不會(huì)改變?cè)次募?#xff0c;sed只是處理源文件的每一行并 把結(jié)果顯示在標(biāo)準(zhǔn)輸出中(當(dāng)然很容易使用重定向來(lái)定制):
sed腳本 描述
sed ’s/^$/d’ price.txt 刪除所有空行
sed ’s/^[ ]*$/d’ price.txt 刪除所有只包含空格或者制表符的行
sed ’s/”//g’ price.txt 刪除所有引號(hào)
轉(zhuǎn)載于:https://www.cnblogs.com/NTTNT/p/6202928.html
總結(jié)
以上是生活随笔為你收集整理的Vim特定行行尾追加的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 伪元素改变date类型input框的默认
- 下一篇: 使用rsync和scp远程同步文件