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编辑效率,建议在实际工作中逐步练习这些命令组合,形成肌肉记忆后编辑速度将大幅提升。
登录后查看全文
热门项目推荐
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C040
MiniMax-M2.1从多语言软件开发自动化到复杂多步骤办公流程执行,MiniMax-M2.1 助力开发者构建下一代自主应用——全程保持完全透明、可控且易于获取。Python00
kylin-wayland-compositorkylin-wayland-compositor或kylin-wlcom(以下简称kywc)是一个基于wlroots编写的wayland合成器。 目前积极开发中,并作为默认显示服务器随openKylin系统发布。 该项目使用开源协议GPL-1.0-or-later,项目中来源于其他开源项目的文件或代码片段遵守原开源协议要求。C01
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7GLM-4.7上线并开源。新版本面向Coding场景强化了编码能力、长程任务规划与工具协同,并在多项主流公开基准测试中取得开源模型中的领先表现。 目前,GLM-4.7已通过BigModel.cn提供API,并在z.ai全栈开发模式中上线Skills模块,支持多模态任务的统一规划与协作。Jinja00
agent-studioopenJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力TSX0120
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00
项目优选
收起
deepin linux kernel
C
26
10
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
434
3.3 K
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
694
367
Ascend Extension for PyTorch
Python
240
274
暂无简介
Dart
694
164
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
React Native鸿蒙化仓库
JavaScript
269
328
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
19
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.22 K
673
仓颉编译器源码及 cjdb 调试工具。
C++
138
869