Project Icon

serpl

终端文本搜索替换工具 提高代码编辑效率

serpl是一款终端用户界面(TUI)应用,用于在整个文件夹中搜索和替换关键词。它支持简单搜索、大小写匹配、全词匹配、正则表达式和AST Grep等多种搜索模式。serpl提供交互式预览、键盘导航和可配置按键绑定功能。这款工具适用于大规模代码重构和快速文本修改,能够提高开发者的工作效率。

Serpl

serpl 是一个终端用户界面(TUI)应用程序,允许用户在整个文件夹中搜索和替换关键词,功能类似于 VS Code 中的搜索替换功能。

https://github.com/yassinebridi/serpl/assets/18403595/348506704-73336074-bfaf-4a9a-849c-bd4aa4e24afc

目录

  1. 功能特点
  2. 安装和更新
  3. 使用方法
  4. 面板
  5. 快速提示
  6. 使用 toggleterm 进行 Neovim 集成
  7. 许可证
  8. 贡献
  9. 致谢
  10. 类似项目

功能特点

  • 在整个项目文件夹中搜索关键词,支持大小写敏感、AST Grep 等选项。
  • 替换关键词,支持保留大小写、AST Grep 等选项。
  • 搜索结果的交互式预览。
  • 键盘导航以提高工作效率。
  • 可配置的键位绑定和搜索模式。

安装和更新

前置条件

  • 系统中已安装 ripgrep
  • (可选)如果想使用 AST Grep 功能,需要安装 ast-grep

安装步骤

  1. 使用 Cargo 安装应用程序:
cargo install serpl
  • 如果想安装包含 AST Grep 功能的应用程序,可以使用以下命令:
    cargo install serpl --features ast_grep
    
  1. 运行应用程序:
serpl

二进制文件

查看发布页面获取最新的二进制文件。

特定操作系统安装

Brew

可以使用 Homebrew 安装 serpl

brew install serpl

Arch Linux

可以使用 pacman官方仓库安装 serpl

pacman -S serpl

Nix/NixOS

自 24.11 版本起,serpl 已包含在 nixpkgs 中,可以通过 Nix 以不同方式安装:

在独立的 Nix 设置中

nix profile install nixpkgs#serpl

在 NixOS 中(通过 configuration.nix 或类似文件):

{pkgs, ...}: {
  environment.systemPackages = [pkgs.serpl];
}

在 Home-Manager 中

{pkgs, ...}: {
  home.packages = [pkgs.serpl];
}

使用方法

基本命令

  • 在当前目录启动应用程序:
    serpl
    
  • 启动应用程序并提供项目根路径:
    serpl --project-root /path/to/project
    

键位绑定

默认键位绑定可以通过 config.json 文件自定义。

默认键位绑定

快捷键组合操作
Ctrl + c退出
Ctrl + b帮助
Tab在标签页之间切换
Backtab切换到上一个标签页
Ctrl + o处理所有文件的替换
r处理选定文件或行的替换
Ctrl + n切换搜索和替换模式
Enter执行搜索(用于大型文件夹)
g / 左箭头 / h转到列表顶部
G / 右箭头 / l转到列表底部
j / 下箭头移动到下一项
k / 上箭头移动到上一项
/搜索结果列表
d删除选定的文件或行
Esc退出当前面板或对话框
Enter(在对话框中)/ y确认操作
Esc(在对话框中)/ n取消操作
hlTab(在对话框中)导航对话框选项

配置

serpl 使用配置文件来管理快捷键绑定和其他设置。默认情况下,可以通过运行 serpl --version 找到配置文件的路径。您可以使用各种文件格式进行配置,如 JSON、JSON5、YAML、TOML 或 INI。

配置示例

JSON
{
  "keybindings": {
    "<Ctrl-d>": "Quit",
    "<Ctrl-c>": "Quit",
    "<Tab>": "LoopOverTabs",
    "<Backtab>": "BackLoopOverTabs",
    "<Ctrl-o>": "ProcessReplace",
    "<Ctrl-b>": "ShowHelp"
  }
}
JSON5
{
  keybindings: {
    "<Ctrl-d>": "Quit",
    "<Ctrl-c>": "Quit",
    "<Tab>": "LoopOverTabs",
    "<Backtab>": "BackLoopOverTabs",
    "<Ctrl-o>": "ProcessReplace",
    "<Ctrl-b>": "ShowHelp",
  },
}
YAML
keybindings:
  "<Ctrl-d>": "Quit"
  "<Ctrl-c>": "Quit"
  "<Tab>": "LoopOverTabs"
  "<Backtab>": "BackLoopOverTabs"
  "<Ctrl-o>": "ProcessReplace"
  "<Ctrl-b>": "ShowHelp"
TOML
[keybindings]
"<Ctrl-d>" = "Quit"
"<Ctrl-c>" = "Quit"
"<Tab>" = "LoopOverTabs"
"<Backtab>" = "BackLoopOverTabs"
"<Ctrl-o>" = "ProcessReplace"
"<Ctrl-b>" = "ShowHelp"
INI
[keybindings]
<Ctrl-d> = Quit
<Ctrl-c> = Quit
<Tab> = LoopOverTabs
<Backtab> = BackLoopOverTabs
<Ctrl-o> = ProcessReplace
<Ctrl-b> = ShowHelp

您可以通过修改所选格式的配置文件来自定义快捷键绑定。

面板

搜索输入

  • 用于输入搜索关键词的输入框。
  • 切换搜索模式(简单、匹配大小写、匹配整词、匹配大小写整词、正则表达式、AST Grep)。
    • 简单:搜索关键词的所有出现。
    • 匹配大小写:搜索与关键词大小写相同的出现。
    • 匹配整词:搜索与关键词完全匹配的出现。
    • 匹配大小写整词:搜索与关键词完全匹配且大小写相同的出现。
    • 正则表达式:使用正则表达式搜索出现。
    • AST Grep:使用 AST Grep 搜索出现。

[!提示] 如果当前目录相当大,您需要按 Enter 键开始搜索。

替换输入

  • 用于输入替换文本的输入框。
  • 切换替换模式(简单、保留大小写、AST Grep)。
    • 简单:替换关键词的所有出现。
    • 保留大小写:替换出现的同时保留关键词的大小写。
    • AST Grep:使用 AST Grep 替换出现。

搜索结果面板

  • 带有搜索结果的文件列表。
  • 选择和查看文件的导航。
  • 从搜索结果中删除文件的选项。
  • 搜索结果计数和当前文件计数。
  • 使用"/"键搜索列表的功能。

预览窗格

  • 显示带有高亮搜索结果和上下文的选定文件。
  • 在文件内查看不同匹配项的导航。
  • 删除包含匹配项的单行的选项。

快速提示

  • 使用"Ctrl + b"组合键显示帮助对话框。
  • 使用"Ctrl + o"组合键处理所有文件的替换。
  • 使用"r"键处理选定文件或行的替换。
  • 使用"Ctrl + n"组合键在搜索和替换模式之间切换。
  • 使用"g"、"G"、"j"和"k"键浏览搜索结果。
  • 使用"d"键删除选定的文件或行。

使用toggleterm集成Neovim

查看 toggleterm.nvim 插件,它为Neovim提供了一个可以通过快捷键切换的终端。 或者,如果你使用 AstroNvim,可以使用以下配置:

return {
  "akinsho/toggleterm.nvim",
  cmd = { "ToggleTerm", "TermExec" },
  dependencies = {
    {
      "AstroNvim/astrocore",
      opts = function(_, opts)
        local maps = opts.mappings
        local astro = require "astrocore"
        maps.n["<Leader>t"] = vim.tbl_get(opts, "_map_sections", "t")

        local serpl = {
          callback = function()
            astro.toggle_term_cmd "serpl"
          end,
          desc = "ToggleTerm serpl",
        }
        maps.n["<Leader>sr"] = { serpl.callback, desc = serpl.desc }

        maps.n["<Leader>tf"] = { "<Cmd>ToggleTerm direction=float<CR>", desc = "ToggleTerm float" }
        maps.n["<Leader>th"] = { "<Cmd>ToggleTerm size=10 direction=horizontal<CR>", desc = "ToggleTerm horizontal split" }
        maps.n["<Leader>tv"] = { "<Cmd>ToggleTerm size=80 direction=vertical<CR>", desc = "ToggleTerm vertical split" }
        maps.n["<F7>"] = { '<Cmd>execute v:count . "ToggleTerm"<CR>', desc = "Toggle terminal" }
        maps.t["<F7>"] = { "<Cmd>ToggleTerm<CR>", desc = "Toggle terminal" }
        maps.i["<F7>"] = { "<Esc><Cmd>ToggleTerm<CR>", desc = "Toggle terminal" }
        maps.n["<C-'>"] = { '<Cmd>execute v:count . "ToggleTerm"<CR>', desc = "Toggle terminal" }
        maps.t["<C-'>"] = { "<Cmd>ToggleTerm<CR>", desc = "Toggle terminal" }
        maps.i["<C-'>"] = { "<Esc><Cmd>ToggleTerm<CR>", desc = "Toggle terminal" }
      end,
    },
  },
  opts = {
    highlights = {
      Normal = { link = "Normal" },
      NormalNC = { link = "NormalNC" },
      NormalFloat = { link = "NormalFloat" },
      FloatBorder = { link = "FloatBorder" },
      StatusLine = { link = "StatusLine" },
      StatusLineNC = { link = "StatusLineNC" },
      WinBar = { link = "WinBar" },
      WinBarNC = { link = "WinBarNC" },
    },
    size = 10,
    ---@param t Terminal
    on_create = function(t)
      vim.opt_local.foldcolumn = "0"
      vim.opt_local.signcolumn = "no"
      if t.hidden then
        local toggle = function() t:toggle() end
        vim.keymap.set({ "n", "t", "i" }, "<C-'>", toggle, { desc = "Toggle terminal", buffer = t.bufnr })
        vim.keymap.set({ "n", "t", "i" }, "<F7>", toggle, { desc = "Toggle terminal", buffer = t.bufnr })
      end
    end,
    shading_factor = 2,
    direction = "float",
    float_opts = { border = "rounded" },
  },
}

许可证

本项目采用MIT许可证。详情请见 LICENSE 文件。

贡献

(正在完善中)

致谢

  • 本项目受到 VS Code 搜索和替换功能的启发。
  • 本项目使用了出色的 ratatui.rs 库构建,并基于其组件模板开发。
  • 感谢 ripgrep 项目提供的搜索功能。
  • 感谢 ast-grep 项目提供的 AST Grep 功能。

类似项目

  • repgrep:一个交互式的 ripgrep 替换工具,可以在命令行上轻松地在文件中查找和替换内容。
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号