乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      vim查找替換功能總結(jié)

       e3399 2010-07-14
      :[range]s/pattern/string/[c,e,g,i]5.1

      range 指的是範圍,1,7 指從第一行至第七行,1,$ 指從第一行至最後一行,也就是整篇文章,也可以 % 代表。還記得嗎? % 是目前編輯的文章,# 是前一次編輯的文章。
      pattern 就是要被替換掉的字串,可以用 regexp 來表示。
      string 將 pattern 由 string 所取代。
      c confirm,每次替換前會詢問。
      e 不顯示 error。
      g globe,不詢問,整行替換。
      i ignore 不分大小寫。

      g 大概都是要加的,否則只會替換每一行的第一個符合字串??梢院掀饋碛?,如 cgi,表示不分大小寫,整行替換,替換前要詢問是否替換。

      [實例] :%s/Edwin/Edward/g
      這樣整篇文章的 Edwin 就會替換成 Edward。

      更進階的搜尋、替換的例子在說明 regexp 的時候還會再詳述。目前只知道最基本的用法就可以了!其實光這樣就非常好用了。:-)

      2、替換說明(示例 )

      VIM中常用的替換模式總結(jié)。

      1,簡單替換表達式

      1. 搜索并替換。輸入:[range]s/from/to/[flags]命令可以搜索匹配的字符串并且替換為指定的 字符串。這是一個稍微復雜的命令。其中[range]是一個可選項,用來指定搜索替換的范圍。[flags]也是一個可選項,用來指定搜索替換的處理方 式。所以這個命令的簡單形式是:s/from/to/。
        1. 搜索替換的范圍。如果沒有指定范圍,則只在當前行進行搜索替換。
          1. 在所有行進行搜索替換。范圍符號%表示在所有行進行搜索替換。:%s/from/to/就是在全文查找from并替換為to。
          2. 在指定的行上進行搜索替換。:1,50s/from/to/表示在第1行和第50行之間(包括1和50行)進行搜索和替換。:45s/from/to/表示僅僅在第45行進行搜索和替換。而"1,$"行號范圍和“%“是等價的。



      替換命令可以在全文中用一個單詞替換另一個單詞:

      :%s/four/4/g


      “%” 范圍前綴表示在所有行中執(zhí)行替換。最后的 “g” 標記表示替換行中的所有匹配點。如果僅僅對當前行進行操作,那么只要去掉%即可

      如果你有一個象 “thirtyfour” 這樣的單詞,上面的命令會出錯。這種情況下,這個單詞會被替換成”thirty4″。要解決這個問題,用 “\<” 來指定匹配單詞開頭:

      :%s/\<four/4/g

      顯然,這樣在處理 “fourty” 的時候還是會出錯。用 “\>” 來解決這個問題(全詞匹配):

      :%s/\<four\>/4/g

      如果你在編碼,你可能只想替換注釋中的 “four”,而保留代碼中的。由于這很難指定,可以在替換命令中加一個 “c” 標記,這樣,Vim 會在每次替換前提示你:

      :%s/\<four\>/4/gc

      2,刪除多余的空格

      要刪除這些每行后面多余的空格,可以執(zhí)行如下命令:

      :%s/\s\+$//

      命令前面指明范圍是 “%”,所以這會作用于整個文件。”substitute” 命令的匹配模式是

      “\s\+$”。這表示行末($)前的一個或者多個(\+)空格(\s)。替換命令的 “to” 部分是空的:”//”。這樣就會刪除那些匹配的空白字符。

      3,匹配重復性模式

      星號項 “*” 規(guī)定在它前面的項可以重復任意次。因此:

      /a*

      匹 配 “a”,”aa”,”aaa”,等等。但也匹配 “” (空字串),因為零次也包含在內(nèi)。星號 “*” 僅僅應(yīng)用于那個緊鄰在它前面的項。因此 “ab*” 匹配 “a”,”ab”,”abb”,”abbb”,等等。如要多次重復整個字符串,那么該字符串必須被組成一個項。組成一項的方法就是在它前面加 “\(”,后面加 “\)”。因此這個命令:

      /\(ab\)*

      匹配: “ab”,”abab”,”ababab”,等等。而且也匹配 “”。

      要避免匹配空字串,使用 “\+”。這表示前面一項可以被匹配一次或多次。

      /ab\+

      匹配 “ab”,”abb”,”abbb”,等等。它不匹配 后面沒有跟隨 “b” 的 “a”。

      要匹配一個可選項,用 “\=”。 例如:

      /folders\=

      匹配 “folder” 和 “folders”。

      4,指定重復次數(shù)

      要匹配某一項的特定次數(shù)重復,使用 “\{n,m}” 這樣的形式。其中 “n” 和 “m” 都是數(shù)字。在它前面的那個項將被重復 “n” 到 “m” 次 (|inclusive| 包含 “n” 和 “m”)。例如:

      /ab\{3,5}

      匹配 “abbb”,”abbbb” 以及 “abbbbb”。

      當 “n” 省略時,被默認為零。當 “m” 省略時,被默認為無限大。當 “,m” 省略時,就表示重復正好 “n” 次。例如:

      模式 匹配次數(shù)

      \{,4} 0,1,2,3 或 4

      \{3,} 3,4,5,等等

      \{0,1} 0 或 1,同 \=

      \{0,} 0 或 更多,同 *

      \{1,} 1 或 更多,同 \+

      \{3} 3

      5,多選一匹配

      在一個查找模式中,”或” 運算符是 “\|”。例如:

      /foo\|bar

      這個命令匹配了 “foo” 或 “bar”。更多的抉擇可以連在后面:

      /one\|two\|three

      匹配 “one”,”two” 或 “three”。

      如要匹配其多次重復,那么整個抉擇結(jié)構(gòu)須置于 “\(” 和 “\)” 之間:

      /\(foo\|bar\)\+

      這個命令匹配 “foo”,”foobar”,”foofoo”,”barfoobar”,等等。

      再舉個例子:

      /end\(if\|while\|for\)

      這個命令匹配 “endif”,”endwhile” 和 “endfor”。

        本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多