Vim文本编辑技巧:runpaint/vim-recipes中的删除操作详解
2025-06-09 12:52:12作者:翟萌耘Ralph
作为一款强大的文本编辑器,Vim提供了多种高效的文本删除方式。本文将深入解析runpaint/vim-recipes项目中关于文本删除的核心技巧,帮助Vim用户掌握专业级的文本编辑能力。
基础删除操作
字符级删除
在普通模式下,最基本的删除操作是使用x键(记忆方法:expunge,意为"删除"):
x:删除光标所在位置的字符X:删除光标前一个字符
这两个命令适合处理单个字符的删除需求,是Vim中最简单的删除方式。
基于动作的删除
Vim提供了更强大的d命令配合动作指令(motion)来实现更灵活的删除:
d{motion}
例如:
dw:删除到下一个单词开头d$:删除到行尾dG:删除到文件末尾
这种删除方式可以精确控制删除范围,是Vim高效编辑的核心技巧之一。
行级删除操作
整行删除
dd命令可以删除整行内容:
dd:删除当前行2dd:删除当前行及下一行(共2行):17,20d:删除17到20行(Ex命令模式)
行尾删除
D命令可以删除从光标位置到行尾的所有内容:
- 如果光标在"Hello world"的"w"上,执行
D后变为"Hello"
可视化模式删除
在可视化模式下(通过v、V或Ctrl+v进入),选中文本区域后:
x或d:删除选中的文本块
Vim删除机制深入解析
Vim的删除操作不仅仅是简单的移除文本,它采用了智能的寄存器管理系统:
-
寄存器分类:
- 小量删除(小于一行):存入
"-寄存器 - 大量删除(整行或更多):存入
"0寄存器
- 小量删除(小于一行):存入
-
寄存器轮转机制:
- 新删除内容存入
"0 - 原
"0内容移至"1 - 原
"1内容移至"2 - 依此类推,直到
"9
- 新删除内容存入
-
删除历史查看:
:registers命令可查看所有寄存器内容"2p可粘贴第3次最近删除的内容("0是最近一次)
实用技巧与建议
-
删除与撤销:
- 误删时可使用
u撤销 - 大范围删除前建议先保存文件
- 误删时可使用
-
删除效率提升:
- 结合数字前缀使用:
3dw删除3个单词 - 搭配文本对象:
di"删除引号内内容
- 结合数字前缀使用:
-
寄存器管理:
- 重要删除内容可指定寄存器:
"add将当前行删除到a寄存器 - 命名寄存器(a-z)不会自动轮转,适合存储重要片段
- 重要删除内容可指定寄存器:
掌握这些删除技巧可以显著提升Vim编辑效率,建议在实际工作中逐步练习这些命令组合,形成肌肉记忆后编辑速度将大幅提升。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0191
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0116
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java04
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08
项目优选
收起
暂无描述
Dockerfile
763
4.96 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
856
1.92 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
676
1.33 K
Ascend Extension for PyTorch
Python
719
875
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
455
437
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.07 K
1.09 K
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
150
252
CANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。
Jupyter Notebook
297
114
昇腾LLM分布式训练框架
Python
178
220