老板說,Vim宏都不會用,你的工作效率太低啦~


工作中,對於文本文件的編輯我們經常有這樣的需求:

  • 多次重復輸入一段相同文本;
  • 生成一段序列化的文本;
  • 每行文本插入一句相同的文本。

除此之外,還有很多需要重復操作的動作。對於這些需求,如果我們人工去操作的話,肯定是非常枯燥乏味,並且要浪費很多時間精力。

這時, Vim 宏就派上用場了,它可以通過一些簡單的步驟快速完成這些重復性的操作,省時省力!下面詳細講解。

宏的錄制和運行

宏的錄制

  1. 在 Vim 編輯器中創建新文件或打開現有文件;
  2. q 並跟上 宏名 開始錄制。假設我們想要將宏名命名為 b ,則按 Escqb 開始錄制;
  3. 文本編輯ing……
  4. q 停止錄制。至此,宏的錄制已完成。

宏的運行

@宏名 即可運行宏一次,按 次數@宏名 重復運行宏多次。

下面給出實例來詳細介紹。

示例-1:使用宏多次生成相同的文本

例如我們要生成 100 行一樣的文字,一種比較笨的辦法就是復制然后粘貼所需要的遍數。這種效率非常低,而且非常容易出錯。有了宏這個工具,一切變得超級簡單!

首先,我們在 Vim 編輯器中創建一個名為 file1.txt 的新文件。

file

然后,我們按 q 之后再按 z 開始錄制宏。這里的 z 就是 宏名 ,后面會用到。如果錄制正確,底部就會出現 recording @z 字樣。

再之后,按 i 然后輸入要需要重復的文本。比如這里輸入文本 Learning Vim Macros

最后按 q 停止錄制,這時 recording @z 就會從底部消失。這樣,一個名為 z 的 宏就錄制完成了,后續我們就可以利用這個宏來重復完成文字錄入工作。

如果你想運行一次剛剛創建的宏,那么將光標移動到文件的所需位置,然后並按 @z 就可以了,這時文字就會被復制一遍。

如果你想要復制 N 多次這行文字,則可以多次運行剛剛那個宏。此時只需在宏前面加 次數 即可。例如 4@z 就可以運行剛才的宏 4 次,相應文字就會被復制 4 遍。

示例-2:使用宏生成序列號

在示例-1里我們是機械重復復制一堆一樣的文字,那如果想要生成帶序列的文本該如何處理?使用宏也可以輕松完成!

假設我們要生成 101-110 的一系列數字,我們一起來完成這個需求。

首先,在 Vim 編輯器中創建一個名為 file2.txt 的新文件,接着按 i 鍵入 101.

ESC 退出鍵入。然后再按 qy 以宏名稱 y 開始錄制后續的操作。我們將光標移到第一行的開頭並按 yy 復制文本,然后按 p 將文本粘貼到下一行。

接着,按 Ctrl + a 將第二行的值從 101 增加到 102 。最后,像之前一樣按 q 停止錄制,我們的宏就制作完成了。

接下來,就是見證奇跡的時刻!

我們鍵入 8@y ,剛剛所錄制的宏就會運行 8 次,生成從 103110 的連續數字。一鍵操作,簡單高效!

這對於一些帶有序列性的文本非常有用,你就無需再重復去做 復制-->改數字 這樣重復枯燥的工作,同時效率也會大大提升!

示例-3:在文件的每一行中添加相同的文本

我們在操作數據庫的時候,很多情況下一些語句非常相似,比如 insert into items values(100, 20077100050, alvin) 這樣的文本,會重復很多次。假如我們現在已經有了要插入的數據,如何快速生成多條 SQL 語句?

在這個例子里,我們假設數據文件 file3.txt 有 4 條數據,如下圖示。

首先,我們在 Vim 編輯器中打開數據文件 file3.txt ,然后按 ESC ,再然后按 qd 以宏名 d 開始錄制。

將光標轉到文件的開頭,按 i 鍵插入文本。然后再輸入 insert into items values( ,再接着按 ESCwyw 5 次。

在這里,w 用於轉到下一個單詞,yw 用於復制當前單詞。之所以這里要 5 次是因為這里每行有五部分。分別是 11001 , HDD , Samsung (注意逗號也算一部分)。

之后,按 ESCa 鍵將光標移動到行尾,再輸入 );

最后,按 j 然后按 q 。這里,j 用於移動到下一行,q 用於停止錄制。這樣我們所需要的宏就制作完成了。

現在,我們想要讓下面剩下的 3 行的文本都處理成第一行那樣的格式,直接按 3@d 運行宏 3 次就可以實現。這樣一來,在數據庫中進行插入就會方便很多,而且我們無需手動一個個去更改,簡單高效!

結論

我們在寫代碼過程中,有很多場合文本、代碼高度相似,如果我們手動去一個個修改的話,那效率將會非常低。有了 Vim 下宏這個神器,我們可以通過創建和使用不同類型的宏來完成這些重復性工作,從而節省時間和精力,實現高效編輯。

看完的都是真愛,點個贊再走唄?您的「三連」就是良許持續創作的最大動力!

  1. 關注原創公眾號「良許Linux」,第一時間獲取最新Linux干貨!
  2. 公眾號后台回復【資料】【面試】【簡歷】獲取精選一線大廠面試、自我提升、簡歷等資料。
  3. 關注我的博客:lxlinux.net


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM