Quantcast
Channel: Vimタグが付けられた新着記事 - Qiita
Viewing all articles
Browse latest Browse all 5608

脱初心者を目指すなら知っておきたい便利なVimコマンド20選 (Vimmerレベル診断付き)

$
0
0

はじめに: Vimならではの便利機能をマスターしよう!

かれこれ数年前、僕がVim(というか、たぶんVi)と初対面したときは、「なんて使いにくいエディタなんだ!!」と最悪の印象でした。

しかし、周りのプログラマやネット上のエンジニアたちはみんな「Vim便利!」「Vim最高!」と言います。
なのでその言葉を信じ、僕も最悪の印象だったVimともう一度正面から向き合うことにしました。

そして、月日が過ぎ・・・僕もいつしか「Vim便利!」「Vim最高!」と叫ぶようになってしまいました!!

これって洗脳?

いやいや、洗脳じゃありませんw

Vimにはメモ帳の延長線上にあるエディタでは実現できないような数々の便利な機能があります。
覚えるまでにはちょっと苦労しますが、覚えてしまえばメモ帳系のエディタでは追いつけないようなスピードでテキストを編集することができます。

とはいえ、そもそも覚える以前に「そんなコマンドがあるとは知らなかった」というのであれば、いつまで経っても作業効率は上がりません。

そこでこの記事では「これはVimならではだね!」と僕が個人的に感じている 便利機能ベスト20をまとめました。
さらに、言葉だけではその便利さが伝わりにくいので、すべてアニメーションGIF付きで説明しています。

Vimは使い始めたけど、まだイマイチ便利さがわからない、もっと便利な機能があるかもしれないけど、面倒くさくて調べてない、というVim初心者の方はぜひ参考にしてみてください!

また、本文の最後であなたの「Vimmerレベル」を診断するおまけコーナーも載せていますw

この記事ではMacVimを使っています

僕が普段使っているのはMacVimです。
動作確認もMacVimで行っています。
ただし、この記事で紹介している機能はMacVim以外のVimでも同じように動作するはずです。

Vim.png

(2014.06.12 17:00追記) さらに便利コマンドを追記するかも?

ネット上の反応を参考にしながら後日「みんなが知らなさそうな便利コマンド」をさらに追記するかもしれません。
この記事を「ストック」してもらうと、便利コマンドを追記した際に変更通知を受け取ることができます。
追記されるコマンドが気になる方は ストックをどうぞ!

カーソル移動・画面スクロール系

w/e/b/W/E/Bを使い分けて単語単位に移動する

ノーマルモードでwとタイプすると、次の単語に移動します。
eは単語の最後の文字に移動します。
bは手前にある単語の先頭に移動します。

また、W/E/Bとタイプすると、ドット(.)やコロン(:)のような記号もひと続きの単語とみなして移動します。

ewb.gif

3wのように数字を付けてタイプすると「3つ先にある単語へ移動」という意味になります。

状況に応じて適切な移動用コマンドを使い分けると効率的です。

H/M/Lでカーソルをウインドウ内の上/中/下に移動させる

ノーマルモードでHとタイプすると、カーソルが現在表示されているウインドウ内の一番の上の行に移動します。
同様にMで中央、Lで最下行に移動します。

HML.gif

z<enter>/z./z-で現在のカーソル位置を基準に画面をスクロールさせる

ノーマルモードでz<enter>(またはzt)とタイプすると、現在カーソルのある行が画面の一番上になるように画面がスクロールします。
同様に、z.で中央、z-で一番下にスクロールします。

zzz.gif

Ctrl-f/Ctrl-b/Ctrl-e/Ctrl-yで画面を上下にスクロールさせる

ノーマルモードでCtrl-fとタイプすると1画面分下へスクロールします。
Ctrl-bは1画面分上へスクロールします。

Ctrl-eは画面を1行分下へスクロールさせます。
Ctrl-yは1行分上へスクロールさせます。

c-e.c-y.gif

編集系

i/a/s/cw/I/A/S/Cを使い分けて挿入モードに入る

ノーマルモードでiとタイプすると、カーソルの左側に文字が挿入できるようになります。
aとタイプするとカーソルの右側に文字が挿入できます。
sはカーソル上の1文字を削除してから挿入モードに入ります。
cwはカーソル上の単語を削除してから挿入モードに入ります。(単語の途中にカーソルがある場合は、そこから単語の末尾までを削除します)

また、Iは行の先頭から、Aは行の末尾から文字を挿入できます。
Sは行全体を削除してから挿入モードに入ります。
Cは現在のカーソルから行末までを削除してから挿入モードに入ります。

iasc.gif

どれも基本のVimコマンドですが、状況に応じて一番タイプ量が少なく済むコマンドを選べるようになりましょう。

v/c/d/y + f/t/F/T/w/Wの組み合わせを駆使してテキストを編集する

ノーマルモードでf+(任意の文字)とタイプすると、fの次にタイプした文字にカーソルが移動します。
たとえば、faとタイプしたときは次に出現するaにカーソルが移動します。

数字と組み合わせることもできます。
たとえば、2faはふたつ先のaに移動します。

t+(任意の文字)fによく似ていますが、指定した文字の 一つ手前にカーソルが移動するのがfと異なる点です。

F/Tf/tの逆で、カーソルの手前にある文字を探してそこへ移動します。

さて、以上の内容を踏まえた上で、ここからがこのセクションの本題です。

f/t/F/Tはカーソルを移動させるだけでなく、v/c/d/yと組み合わせて使うこともできます。
たとえば、vfaは「次に出現するaまでビジュアル選択する」という意味になります。
c2t(であれば、「二つ先に出現する"("の手前まで削除して挿入モードに入る」という意味になります。

また、v/c/d/yf/t/F/Tだけでなく、w/W(単語選択)と組み合わせるのも効果的です。
たとえば、ywとタイプすると単語全体をヤンク(コピー)します。(カーソルが単語の先頭にある場合)

ftw.gif

このようにコマンドの組み合わせを駆使して、狙った範囲を素早く選択したり削除したりすると非常に効率よくテキストを編集できます。

ci'/dat/vi{/ya"のようなコンビネーションを使い分けてテキストを編集する

ノーマルモードでci'とタイプすると、シングルクオートの内部にある文字列を削除して挿入モードに入ります。
ca'とタイプすると、シングルクオートで囲まれた文字列をシングルクオートごと削除して挿入モードに入ります。

ci"であればダブルクオートで囲まれた文字列を、ci{であれば中括弧({})で囲まれた文字列を、citであればHTMLタグで囲まれた文字列をそれぞれ編集できます。

cの変わりにdを使ってdi'とタイプするとシングルクオートの内部にある文字列を削除します。(挿入モードには入らない)

va'であれば、シングルクオートで囲まれた文字列をシングルクオートごとビジュアル選択します。

このように、

c/d/v/y + a/i + (文字列を囲む記号)

というコンビネーションで、何かに囲まれた文字列を編集したり削除したりすることができます。
HTMLタグで囲まれた文字列を編集するときは記号ではなく、tで指定する点にだけちょっと注意してください。

ai-combi.gif

応用テクニックとして、d2i{のようにタイプすると、2つ外側にある{}の内部文字列を削除したりできます。({}がネストしている場合)

J/gJで行を連結する

ノーマルモードで複数行をビジュアル選択してJとタイプすると、選択された行を連結することができます。
行を連結したときは半角スペースが境目に入ります。

この半角スペースが不要な場合はgJとタイプします。

j-gj.gif

3Jのようにタイプすればビジュアル選択せずに3行分を連結する、ということも可能です。

Ctrl-vで矩形選択する

ノーマルモードでCtrl-vとタイプすると、矩形選択がスタートします。
矩形選択した状態でdとタイプすれば、その範囲を削除できます。
sまたはcとタイプすれば、その範囲を削除した後に挿入モードに入ります。
IまたはAとタイプすれば、選択範囲の先頭または末尾にカーソルが移動して挿入モードに入ります。

C-v.gif

矩形選択+$+Aで、長さの異なる複数行の行末に同じ文字列を追加する

複数の行に渡って同じ文字列を行末に追加したいと思った場合、各行の長さが揃っている場合は矩形選択+Aで編集できますが、長さが揃っていない場合はちょっとひと工夫必要です。

この場合は、まず行方向に矩形選択(Ctrl-v+j)し、次に$をタイプします。(全行を行末までビジュアル選択)
そのあとにAをタイプすると、長さが異なる行であっても同じ文字列を行末に追加できます。

insert-at-tails.gif

>>や複数行選択&>でインデントを変える

ノーマルモードで>>とタイプすると、その行のインデントを1つ増やせます。
反対に<<とタイプすると1つ減らせます。

複数行をビジュアル選択した状態で>とタイプすると、選択した行をまとめてインデントできます。

また、数字と組み合わせてインデントを実行することもできます。
たとえば、2>>とタイプすると、2行に渡ってインデントを1つ増やします。

一方、複数行を選択した状態で2>とタイプすると、その範囲でインデントを2つ増やせます。

indent.gif

複数行選択するときとしないときとで、数字の意味が異なる点に注意してください。

Ctrl-a/Ctrl-xでカーソルの下にある数字を増減させる

ノーマルモードでCtrl-aとタイプすると、カーソルの下にある数字を1つ増やせます。
Ctrl-xは反対に数字を1つ減らします。

C-a.C-x.gif

挿入モードに入らなくて済むのでちょっと便利です。

r/Rを使って1文字/複数の文字を上書きする

ノーマルモードでr+(任意の文字)とタイプすると、カーソルの上にある1文字を上書きします。

また、R+(任意の文字列)+(ESC)とタイプすると、ESCを押すまで上書きを続けます。

rR.gif

~/u/Uで大文字/小文字を切り替える

ノーマルモードで~とタイプすると、カーソルの上にある文字の大文字/小文字を切り替えることができます。
ビジュアル選択している場合に~をタイプすると、選択範囲内にある文字の大文字/小文字を反転させます。

また、ビジュアル選択中にuとタイプすると、選択範囲内にある文字をすべて小文字にします。
Uは反対にすべて大文字にします。

uU.gif

Ctrl-p/Ctrl-nで単語補完する

挿入モードで初めの数文字をタイプし、Ctrl-pまたはCtrl-nとタイプすると、現在開いているバッファの中からその文字列で始まる単語を補完の候補として選択することができます。

C-p.C-n.gif

Ctrl-pは「カーソルの前にあるキーワードと合致する単語を逆方向に検索して挿入」、Ctrl-nは「カーソルの前にあるキーワードと合致する単語を順方向に検索して挿入」という違いはありますが、僕はあまり気にせずにいつもCtrl-pを使っています。

検索・置換系

正規表現検索を使いこなす (Perl系と記述が異なるメタ文字を理解する)

ノーマルモードで/hogeのようにタイプすると、テキスト中に現れる文字列"hoge"を検索できます。

/で検索するときは正規表現が使えます。
たとえば、/^\dのようにタイプすると、「行頭に現れる任意の数字を検索」という意味になります。

ただし、Vimの正規表現で使うメタ文字はPerl系の正規表現で使うメタ文字と少し異なります。
いくつかのメタ文字はバックスラッシュと組み合わせて使う必要があるので、Perl系の正規表現に慣れている人でも注意が必要です。

メタ文字意味
\(hoge\)文字列"hoge"をキャプチャする
hoge\|piyo"hoge"または"piyo"を検索
Regexp\?"Regex"または"Regexp"を検索(pが0または1個)
go\+gle"gooooogle"のような"o"が1個以上連続する"go..gle"を検索
go\{2,4}gle"google"や"goooogle"のように"o"が2個以上4個以下で連続する"go..gle"を検索

上記のメタ文字はバックスラッシュを付けないと普通の文字として検索されます。
たとえば、/go+gleは純粋に"go+gle"という文字列を検索します。

regex.gif

grep検索を活用する

Vimのgrep検索はバリエーションが豊富なので、詳細に説明するとそれだけで一つの記事になってしまいます。
ここでは一つだけ使用例を示します。

ノーマルモードで:vimgrep 'class [A-Z]' **/*.rb | cwのようにタイプすると、拡張子が.rbになっているファイルを対象にして、「class (任意の大文字)」を含む行を検索します。
最後の| cwは検索実行後にQuickfix Listを表示するための命令です。

:cnまたは:cpで次または一つ前の検索結果へ移動することができます。
Quickfix Listから検索結果を選択してジャンプすることもできます。

grep.gif

ただし、僕はfugutive.vimプラグインを使って:Ggrepコマンドで検索することが多いです。
:Ggrepを使うとgitで管理されているファイルだけを対象にして検索することができます。

fugutive.vimについてはこちらのweb記事を参考にしてください。

その他、grep検索に関する詳しい情報は以下のweb記事を参考にしてください。

grep置換を活用する

Vimではgrep検索だけでなく、grep置換をすることもできます。

grep置換をする場合は以下のように2つのコマンドを発行する必要があります。

:args **/*.rb
:argdo %s/tel/phone/gc |update

上の例では次のようなgrep置換を実施します。

  • 拡張子が.rbになっているファイルを対象にする(:args **/*.rb)
  • "tel"を"phone"に置換する(/tel/phone/g)
  • 置換する際に一つずつ確認を入れる(/gcc)
  • 置換が終わったらファイルを保存する(| update)

replace.gif

バッファ・ウインドウ操作系

:lsで現在開いているバッファを確認する

ノーマルモードで:lsとタイプすると現在開いているバッファの一覧が表示されます。
"+"マークの付いているファイルはまだ保存していないファイルです。
先頭に表示されている番号はバッファ番号です。
:b3のようにタイプするとその番号のバッファを表示できます。

ls.gif

ただし、僕はUnite.vimプラグインのバッファ一覧もよく活用します。
Unite.vimを使うと現在開いているバッファの一覧を表示してくれるだけでなく、ファイル名で絞り込んだりカーソルを上下に移動させて目的のファイルを開いたりすることができます。

Unite.vimについてはこちらのweb記事を参考にしてください。

Ctrl-w v/Ctrl-w sでウインドウを分割する

ノーマルモードでCtrl-w vとタイプするとウインドウを縦方向に分割できます。
Ctrl-w sとタイプすると横方向に分割できます。

ウインドウを移動する場合は以下のようなコマンドが使えます。

  • Ctrl-w w: 次のウインドウへ
  • Ctrl-w W: 前のウインドウへ
  • Ctrl-w h: 左へのウインドウへ(j/k/lなら下/上/右へ)

ウインドウを閉じるときは:qとタイプします。

C-w.gif

Vimmerレベル診断

さて、上で紹介したVimコマンドは全部で20種類ありました。
このうち、あなたが普段使いこなしているコマンドはいくつありましたか?

1項目1ポイントとして、自分のVimmerレベルを採点してみましょう!

  1. w/e/b/W/E/Bを使い分けて単語単位に移動する
  2. H/M/Lでカーソルをウインドウ内の上/中/下に移動させる
  3. z<enter>/z./z-で現在のカーソル位置を基準に画面をスクロールさせる
  4. Ctrl-f/Ctrl-b/Ctrl-e/Ctrl-yで画面を上下にスクロールさせる
  5. i/a/s/cw/I/A/S/Cを使い分けて挿入モードに入る
  6. v/c/d/y + f/t/F/T/w/Wの組み合わせを駆使してテキストを編集する
  7. ci'/dat/vi{/ya"のようなコンビネーションを使い分けてテキストを編集する
  8. J/gJで行を連結する
  9. Ctrl-vで矩形選択する
  10. 矩形選択+$+Aで、長さの異なる複数行の行末に同じ文字列を追加する
  11. >>や複数行選択+>でインデントを変える
  12. Ctrl-x/Ctrl-aでカーソルの下にある数字を増減させる
  13. r/Rを使って1文字/複数の文字を上書きする
  14. ~/u/Uで大文字/小文字を切り替える
  15. Ctrl-p/Ctrl-nで単語補完する
  16. 正規表現検索を使いこなす (Perl系と記述が異なるメタ文字を理解する)
  17. grep検索を活用する
  18. grep置換を活用する
  19. :lsで現在開いているバッファを確認する
  20. Ctrl-w v/Ctrl-w sでウインドウを分割する

0ポイント: これからVimmer

Vimを普段使っている人ならさすがに0ポイントということはないはずです。
あなたはきっと、これからVimを使おうと考えている人ですね?
いらっしゃいませ、ようこそVimの世界へ!

1~5ポイント: ひよっこVimmer

Vimでコーディングはしていても、まだまだVimのイロハぐらいの機能しか使いこなしていませんね?
まずはもっと基礎を固めてから、それから応用力を付けていきましょう!

6ポイント~10ポイント: 初級Vimmer

そろそろVimの若葉マークは外れたころですね。
でもまだまだ伸びる余地はあるので、ここで怠けずにもっとコマンドを覚えていきましょう!

11ポイント~19ポイント: 中級Vimmer

このあたりのポイントになるとそれなりにVimの経験がある人だと思います。
とはいえ、Vimにはあなたの作業効率を向上させる機能がまだ隠されているようです。
ネットや書籍で上級者向けのコマンドや機能を学習すればより完璧ですね!

満点(20ポイント): ひょっとして、達人Vimmer!?

すごい!!あなたはたぶん普段からバリバリとVimを使いこなしている 達人Vimmerさんですね?
たぶんVimのスキルは僕なんかよりもずっと上なんだと思います。
「このコマンドもすごく便利なんだけど、ちゃんと使えてる?」という情報があったらコメント等で教えてください!

まとめ

というわけで今回は、個人的に「これはVimならでは」と感じている便利機能を20個集めてみました。

もちろん、Vimの便利機能はこれだけに限りません。
ここで取り上げなかったものもいくつかありますし、僕自身が勉強不足で使いこなせていない便利機能もたくさんあると思います。

誰でもエディタを使いこなせば使いこなすほど、開発の効率はどんどん上がっていきます。
「なんとなく使えてるからまあいいや」ではなく、「もっと効率よく開発できないか?」と自分に問いかけながら、エディタの操作に習熟していきましょう!

あわせて読みたい

脱初心者を目指すVimmerにオススメしたいVimプラグインや.vimrcの設定 - Qiita
こちらは便利なプラグインや.vimrcの設定について紹介したQiita記事です。

僕がサクラエディタからVimに乗り換えるまで - give IT a try
数年前は僕も全くVimが使えず、サクラエディタのような「メモ帳の延長線上にあるテキストエディタ」を使っていました。
そんな僕がVimに乗り換えようと思った動機と、乗り換えるまでにやったトレーニング(?)の数々を公開しています。

Vimコマンドを定期的にツイートするbotも作っています

Vimコマンドの勉強用に作った @be_vimmer_jpというbotがあります。
このbotをフォローすると定期的にVimコマンドの内容をランダムにツイートしてくれます。
よかったらフォローしてみてください。

@be_vimmer_jp
be_vimmer.png

開発の経緯はこちらのブログエントリにまとめてあります。

Vimコマンドを定期的に解説してくれるTwitterボットを作りました - give IT a try


Viewing all articles
Browse latest Browse all 5608

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>