Vimでは、行の最初の数件の一致を置き換える機会がある場合がありますが、g
のようにすべてが一致するわけではありません。例えば。:
_a a a a a
_
に
_b b b a a
_
_:s/a/b/[enter]:[up][enter]:[up][enter]
_を使用できることはわかっていますが、これは3回の繰り返しで十分に退屈です。
私はもう試した:
:s/a/b/3g
_:vimが末尾の文字について不平を言いました。:s/a/b/3
_:この最初の出現と次の2行を変更します。3:s/a/b
_:前と同じ。:s/a/b/g3
_:この行と次の2行のすべての出現箇所を変更します。:3s/a/b
_:3行目の最初の出現箇所を変更します。:/a/,3/a/s/a/b
_:ファイル内の次のa
とa
を含む3行目の間にある各行の最初の出現を変更します(必要に応じて反転するように要求します)。:/a/,/\([^a]*a\)\{3\}/s/a/b/
:thisとnextの間の各行の最初の出現箇所を3 a
sで変更します(これは複数文字の検索に簡単に拡張できませんでした)。その他のさまざまなアドレス指定パターンがあり、どれも機能しませんでした。私は、この問題の答えを見つけようとする_:s
_コマンドについてかなりのことを学びましたが、まだ解決していません。
誰でもこれを行う方法を知っていますか?
(特定の範囲のボーナスポイント、たとえば2番目から4番目の出現)
_:s/pattern/replacement/gc
_ idea from Samus _ (これは、置換文字列内にパターンが含まれている場合に正しい操作を保証する最も簡単な方法のようです)に基づいて、2番目から4番目の出現箇所を1つに置き換えますライン:
_:call feedkeys("nyyyq") | s/pat/string/gc
_
feedkeys()
は、入力文字列をキーボード入力キューに入れる関数です。重要なのは、カウントを前もって行うことです。これにより、カウントの喪失や中断を心配する必要がなくなります。
より一般的なケースでは、MthからNthのオカレンスを[〜#〜] n [〜#〜]の1行が非常に大きい以上[〜#〜] m [〜#〜]:
_:call feedkeys(repeat("n", M-1) . repeat("y", N-M+1) . "q") | s/pat/string/gc
_
[〜#〜] m [〜#〜]と[〜#〜] n [〜#〜を置き換えます]必要な値を使用します(自分で計算したくない場合は、vim
に簡単な暗算を実行させることもできます)。 _.
_はVimLの文字列連結演算子であることに注意してください。明らかにこれは大きな[〜#〜] m [〜#〜]のキーストロークのみを保存します。この機能を頻繁に使用する場合は、タイプするのがかなり難しいので、上記をカスタムコマンドまたはカスタム関数に入れる時間を節約できます。
最初の質問については、次のようにします。
:s/a/b
&&
2つ目はトリッキーです。自動で行う方法はわかりませんが、vimで次のように一致するたびにプロンプトを表示させることができます。
:s/a/b/gc
次に、最初のn個の一致に「いいえ」、他の一致に「はい」と応答します。
a a a a a
a a a a a
a a a a a
a a a a a
a a a a a
a a a a a
a a a a a
:3,6g/^/let i=0 | while i<3 | s/a/b/ | let i+=1 | endwhile
a a a a a
a a a a a
b b b a a
b b b a a
b b b a a
b b b a a
a a a a a
私はこれがうまくいくと思います、最初に交換してから2回繰り返します:
:s/a/b/
2@: