Vim多行縮進及高級命令

原文地址: http://blog.csdn.net/topasstem8/article/details/6678215

 Vim多行縮進技巧

1.按v進入visual狀態,選擇多行,用>或<縮進或縮出 

2. 通常根據語言特徵使用自動縮進排版:在命令狀態下對當前行用== (連按=兩次), 或對多行用n==(n是自然數)表示自動縮進從當前行起的下面n行。你可以試試把代碼縮進任意打亂再用n==排版,相當於一般IDE裏的code format。使用gg=G可對整篇代碼進行排版。

3. :10, 40s/word1/word2/c      substitute all word1 between line 10~40 with word2
4.全文字眼替換  %s/source/dist/g 或者 :1,$ s/source/dist/g
  

  1.:s/vivian/sky/ 替換當前行第一個 vivian 爲 sky

  :s/vivian/sky/g 替換當前行所有 vivian 爲 sky

  2. :n,$s/vivian/sky/ 替換第 n 行開始到最後一行中每一行的第一個 vivian 爲 sky

  :n,$s/vivian/sky/g 替換第 n 行開始到最後一行中每一行所有 vivian 爲 sky

  (n 爲數字,若 n 爲 .,表示從當前行開始到最後一行)

  3. :%s/vivian/sky/(等同於 :g/vivian/s//sky/) 替換每一行的第一個 vivian 爲 sky

  :%s/vivian/sky/g(等同於 :g/vivian/s//sky/g) 替換每一行中所有 vivian 爲 sky

  4. 可以使用 # 作爲分隔符,此時中間出現的 / 不會作爲分隔符

  :s#vivian/#sky/# 替換當前行第一個 vivian/ 爲 sky/

  5. 刪除文本中的^M

  問題描述:對於換行,window下用回車換行(0A0D)來表示,linux下是回車(0A)來表示。這樣,將window上的文件拷到unix上用時,總會有個^M.請寫個用在unix下的過濾windows文件的換行符(0D)的shell或c程序。

  · 使用命令:cat filename1 | tr -d “^V^M” > newfile;

  · 使用命令:sed -e “s/^V^M//” filename > outputfilename。需要注意的是在1、2兩種方法中,^V和^M指的是Ctrl+V和Ctrl+M。你必須要手工進行輸入,而不是粘貼。

  · 在vi中處理:首先使用vi打開文件,然後按ESC鍵,接着輸入命令:%s/^V^M//。

  · :%s/^M$//g

  如果上述方法無用,則正確的解決辦法是:

  · tr -d "\r" < src >dest

  · tr -d "\015" dest

  · strings A>B

  6. 其它

  利用 :s 命令可以實現字符串的替換。具體的用法包括:

  :s/str1/str2/ 用字符串 str2 替換行中首次出現的字符串 str1

  :s/str1/str2/g 用字符串 str2 替換行中所有出現的字符串 str1

  :.,$ s/str1/str2/g 用字符串 str2 替換正文當前行到末尾所有出現的字符串 str1

  :1,$ s/str1/str2/g 用字符串 str2 替換正文中所有出現的字符串 str1

  :g/str1/s//str2/g 功能同上

  從上述替換命令可以看到:g 放在命令末尾,表示對搜索字符串的每次出現進行替換;不加 g,表示只對搜索

  字符串的首次出現進行替換;g 放在命令開頭,表示對正文中所有包含搜索字符串的行進行替換操作。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章