Emacs 折腾日记(二十三)——进一步提升编辑效率
liuian 2025-05-23 18:30 4 浏览
在前面的几篇,我们完成了Emacs的vim模拟器、中文输入、多行编辑以及基本的补全功能的添加。这一篇没有具体的提升哪一方面的能力,这一篇我想整合我在其他教程中看到的我认为对我比较有用的用法和插件,算是对前期功能的一个总结。
让Emacs记住一些信息
一般的编辑器都会在下次打开时记住上次的一些信息,例如记住之前打开过的文件,执行过的命令,或者记住上次的窗口布局。
记住上次执行的命令
我们每次使用 M-x 执行命令时,minibuffer中显示的提示都是一样的,那些常用命令要么不在上面要么太靠下了,我们希望能记住某些命令,以便能快速找到它。
记住上次执行的命令可以使用 savehist 插件。它是一个Emacs自带的插件,默认是关闭的状态,我们可以通过将 use-package 来加载它,但是因为是自带的,不需要从镜像中下载所以它的 :ensure 项应该设置为 nil
(use-package savehist
:ensure nil
:hook (after-init . savehist-mode)
:custom
(savehist-file (locate-user-emacs-file "custom/savehist")) ;; 设置保存文件的位置
(savehist-additional-variables '(kill-rings shell-command-history)) ;; 额外保存剪切板和shell命令行历史
(savehist-ignored-variables '(message-history)) ;; 不保存消息历史
(history-delete-duplicates t) ;; 自动去重
(history-length 1000) ;; 保存历史数据条目
)
在执行一些操作关掉Emacs之后,我们会发现它在 ~/.emacs.d/custom 生成了一个名为 savehist 的文件,它记录了之前在minibuffer中执行的命令。为了保持git工程的干净,我打算将这种历史文件排除在git管理之外,所以单独将它放到custom目录,并忽略它
其实该插件不光可以保留执行的命令,minibuffer中的许多信息它都可以保存和持久化。
- minibuffer-history (所有 minibuffer 输入历史)
- command-history (执行过的命令)
- search-ring (搜索历史)
- regexp-search-ring (正则搜索历史)
- extended-command-history (M-x 命令历史)
- file-name-history (文件路径历史)
记住上次打开的文件
一般的编辑器都可以记录上次打开的文件,并列出来。Emacs也有一个类似的内置插件—— recentf
(use-package recentf
:ensure nil
:hook (after-init . recentf-mode)
:custom
(recentf-max-menu-item 10) ;; 最多只记录10条历史记录
(recentf-save-file (locate-user-emacs-file "custom/.recentf")) ;; 定义保存历史记录的临时文件路径
)
搜索功能的增强
实现全局搜索我们可以依赖Linux上的命令行工具 grep 和最近(也不算近了)的 ripgrep。之前在介绍vim的时候,vim内部集成了 grep。但是我们使用更为强大的 ripgrep。在Emacs中可以配合插件 consult 和 ripgrep,调用 consult-ripgrep 来进行全局搜索。它会自动搜索当前项目下的所有目录。
我们对之前 consult 插件的配置代码进行一些修改,并添加 ripgrep 的配置
(use-package consult
:ensure t)
(use-package ripgrep
:ensure t
:after consult
:bind
(("C-s" . consult-ripgrep))
)
这里我们将 C-s 绑定的快捷键修改为 consult-ripgrep。
神奇的是,配合之前安装的orderless,我们只需要按照一个模糊的记忆来匹配想要的内容。
同时它也能支持输入中文
批量替换
批量替换这个功能,根据我找到的教程,它需要依赖 embark、consult、和 wgrep 这么三个插件。其中 consult 用来进行搜索,而 embark 可以为不同场景下的文本/候选项(如搜索结果、补全列表、文件路径等)提供动态的快捷操作菜单。简化了minibuffer上的一些操作。而 wgrep 则是其中的核心插件,用来批量修改内容并保存
(use-package embark
:ensure t
:after consult
:bind
(("C-e" . embark-export)))
(use-package embark-consult
:ensure t
:after embark)
(use-package wgrep
:ensure t
:custom
(wgrep-auto-save-buffer t) ;; 自动保存修改
)
这里我们使用 :after 来保证插件的加载顺序依次为 consult、embark、embark-consult,特别是 embark-consult,它依赖 consult 和 embark,一定要将它放到后面加载。
下面来演示如何进行批量替换,这里我们将配置中所有 use-package 修改为 package-install,修改之前记得使用git等版本管理工具进行备份
- 首先,使用 C-s 搜索 use-package 关键字
- 接着使用 C-e, 也就是上面绑定的快捷键来将结果从 minibuffer 导出到 buffer
- 然后使用 C-c C-p 调用 wgrep-change-to-wgrep-mode 将 buffer 的mode由 grep-mode 修改为 wgrep-mode
- 接着使用 M-% 调用 query-replace 进行替换,这个时候它需要输入被替换的字符和替换后的字符
- 确定后,对于每个待替换的位置使用 y 或者 n 来表示替换或者不替换。也可以使用 ! 替换所有
- 最后使用 C-c C-c 调用 wgrep-finish-edit 来结束编辑,配置之前设置的自动保存,此时修改内容已经被保存了
- 修改之后如何不满意,可以使用 C-c C-k 撤销修改
小节
这应该是最后一篇关于Emacs自身编辑功能的增强了,在这一块我没有使用太多的Emacs经验。倒是在vim上有点经验,所以很多东西我不自觉地就往vim上面靠,总想着vim在编辑上有些功能Emacs上还没有,该如何进行添加,这几篇就显得比较分散,总是想到什么功能就往上面堆。为此造成各位读者阅读体验不佳,我表示道歉。谢谢各位读者的支持和鼓励!
- 上一篇:黑群晖RR引导DT机型,硬盘排序方法~
- 下一篇:grep黑客手里的终级利器
相关推荐
- 用python操作excel、word、pdf非常容易,迅速教会你
-
你会用python操作excel、word、pdf吗?不会也没关系,这篇文章教会你~【文末领取】案例篇幅有限,给大家准备了电子版PDF获取方式:...
- 不同类型的文本、Word文档、Excel文档和图片将它们转换为PDF格式
-
要根据不同类型的文本、Word文档、Excel文档和图片将它们转换为PDF格式,你可以使用Python中的不同库来实现。下面是一个示例代码,展示了如何使用不同的库来处理不同类型的文件并将其转换为PDF...
- 10分钟实现PDF转Word神器!看DeepSeek如何用Python解放打工人
-
开篇痛点每个被PDF折磨过的职场人都懂——领导发来的扫描件要修改,手动抄到Word需要2小时;网上下载的报告想复制数据,却变成乱码…今天我们用Python+DeepSeek,10分钟打造一个智能转换工...
- 第12天 | 12天搞定Python,word和pdf
-
其实,Python除了对excel的支持很nice之外,对word、ppt和pdf也不赖的,上一篇《第12天|12天搞定Python,让excel飞起来》说了excel方面的内容,这一篇补上Py...
- 用python轻松操作excel、word、pdf吗?这篇文章教会你!拿走不谢
-
你会用python操作excel、word、pdf吗?不会也没关系,这篇文章教会你~【文末领取】案例篇幅有限,给大家准备了电子版PDF获取方式:...
- Python开发打印服务(1)
-
Python开发打印服务(1)1.需求背景在项目开发中,我们经常会遇到打印预览、打印的需求。比如:我们在开发进销存或者其他系统应用时,经常会按照客户的需求来定制报表等。在Web项目中,实现打印预览...
- 零代码编程:用ChatGPT将PDF文件的表格批量转为Excel表格
-
电脑中有几百个PDF文件,文件内容格式一致,每个PDF文件第一页是一个表格。想把这几百个PDF文件里面的表格都提取出来,转为excel表,该怎么办?打开ChatGPT(一定要用GPT4,编程能力很强。...
- 用python操作excel、word、pdf非常迅速方便,迅速教会你
-
你会用python操作excel、word、pdf吗?不会也没关系,这篇文章教会你~【文末领取】案例篇幅有限,给大家准备了电子版PDF获取方式:...
- PDF转换技巧:如何免费将 PDF 转换为 Excel
-
随着数字文档的使用不断增加,对高效和值得信赖的文档转换工具的需求也在增加。将PDF文件转换为Excel电子表格(XLS)可能具有挑战性,但这篇文章旨在缓解这些困难。这是带有分步说明的指南。...
- PDF转Excel要收费?python几行代码帮你免费搞定(附代码)
-
写在前面经常在学习或工作中需要从PDF获取一些表格数据,直接用PDF阅读器复制的话,很难复制出来,使用PDF转Excel的软件,又需要收费。这时候,可以使用我们强大的python,几行代码就能把pdf...
- python将PDF格式文档转换为excel文档
-
首先安装pdfplumber库pipinstallpdfplumberopenpyxl然后转换#导入两个模块importpdfplumberimportpandasaspd...
- 用DEEPSEEK写PDF转为Excel 程序
-
今天学校发了《2027通用版普通高校拟在山东招生专业(类)选考科目要求》(本科)文件为PDF版要转为化Excel用DEEPSEEK开发过程提问:写一个把PDF内容按着原来格式转化为EXCELL表格电脑...
- 用DeepSeek+Trae 自己写PDF表格转为EXCEL表格
-
如何将下面PDF表格转为EXCEL能更好统计在TRAE提问:新建窗口-选择文件夹-写一个PDF转excel电脑程序:样式不变,界面有选择文件,有输出文件,显示进度及页码,开始,暂停,退出,实现所...
- Python一行代码实现PDF转Excel
-
第三方包tabula工具适用于从PDF中提取可复制(非图片格式)的表格数据,并输出表格安装pipinstalltabula-py函数调用df=tabula.read_pdf("PDF文件...
- Python教程:python字典zip函数用法 - 学习如何操作字典
-
知识星球:写代码那些事如果你有收获|欢迎|点赞|关注|转发这里会定期更新|大厂的开发|架构|方案设计这里也会更新|如何摸鱼|抓虾欢迎来到写代码那些事!在Python编程中,字典(Dictionary)...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
-
- 用python操作excel、word、pdf非常容易,迅速教会你
- 不同类型的文本、Word文档、Excel文档和图片将它们转换为PDF格式
- 10分钟实现PDF转Word神器!看DeepSeek如何用Python解放打工人
- 第12天 | 12天搞定Python,word和pdf
- 用python轻松操作excel、word、pdf吗?这篇文章教会你!拿走不谢
- Python开发打印服务(1)
- 零代码编程:用ChatGPT将PDF文件的表格批量转为Excel表格
- 用python操作excel、word、pdf非常迅速方便,迅速教会你
- PDF转换技巧:如何免费将 PDF 转换为 Excel
- PDF转Excel要收费?python几行代码帮你免费搞定(附代码)
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- react-admin (33)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)