vim中字串出現次數的統計及字元創替換

2021-06-15 09:46:22 字數 2205 閱讀 6182

vim中字串出現次數的查詢:

在所有行中查詢 字串 出現的次數 

:%s/字串/&/gn 

在m和n行之間查詢 字串 出現的次數

:m,ns/字串/&/gn 

vim中字串的替換:

vi/vim 中可以使用 :s 命令來替換字串。以前只會使用一種格式來全文替換,今天發現該命令有很多種寫法(vi 真是強大啊,還有很多需要學習),記錄幾種在此,方便以後查詢。

:s/vivian/sky/ 替換當前行第乙個 vivian 為 sky

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

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

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

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

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

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

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

:s#vivian/#sky/# 替換當前行第乙個 vivian/ 為 sky/

:%s+/oradata/apras/+/user01/apras1+ (使用+ 來 替換 / ): /oradata/apras/替換成/user01/apras1/

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" 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 放在命令開頭,表示對正文中所有包含搜尋字串的行進行替換操作

上述主要是為了自己以後方便查詢 從網上整理了一下。

統計字串中字元出現次數(延伸)

統計字串中字元出現的次數 1.簡單統計次數 returnstrnum function str,who for var i 0,l str.length i l i return strnum who console.log that.returnstrnum sgdgfdgrrgdv g 4 說明...

利用陣列統計字串中字元出現次數

題目要求 輸入一行包括大寫字母,小寫字母及數字的字串,該字串以 號為結束標記,要求統計指定字元出現次數,能夠實現迴圈操作 題解 通過ascii值之間的關係,開闢乙個陣列,邊輸入邊計數,查詢時通過下標查詢 include using namespace std void count char ch c...

C 統計字串中某字元出現的次數

題目描述 輸入乙個字串s和乙個字元ch,統計並輸出字元ch在字串s 現的總次數。改寫要求 編寫乙個函式,求字元指標p所指向的字串中,字元ch出現的次數,並將該結果作為函式值返回。函式原型為 int countchar char p,char ch 輸入描述 輸出描述 輸出為乙個正整數,表示字元ch出...