VSCode的全局搜索和替换功能怎么用?_正则表达式实战技巧【教程】

8次阅读

vscode全局搜索需手动开启包含子目录、禁用排除设置及dotAll模式:Ctrl+Shift+F打开搜索面板,清空files to exclude并关闭“Use Exclude Settings”,勾选.*按钮启用跨行匹配。

VSCode的全局搜索和替换功能怎么用?_正则表达式实战技巧【教程】

VSCode 的全局搜索和替换功能本身不依赖插件,但默认行为容易让人误以为“没生效”——比如搜索不到 node_modules 里的内容、替换后没保存、正则开启后语法报错却没提示。关键不是“会不会用”,而是“哪些开关必须手动打开”“哪些符号要转义”“哪些场景下 .* 反而匹配不到换行”。

怎么打开真正的全局搜索(含子文件夹)

快捷键 Ctrl+Shift+Fwindows/linux)或 Cmd+Shift+FmacOS)打开搜索面板,但默认会跳过某些目录。必须检查右上角的 files to includefiles to exclude

  • files to include 留空表示搜索所有文件;填 **/*.js 则只搜 JS 文件
  • files to exclude 默认包含 node_modules, dist, out 等,若想搜 node_modules,需手动删掉这一项,或改为 !node_modules/**
  • 搜索前务必点一下右上角的 ... 展开高级选项,确认 Use Exclude Settings and Ignore Files 是否勾选——取消勾选才能无视 .gitignoresettings.json 中的 files.exclude

Ctrl+H 替换时为什么改了但没保存?

VSCode 的替换操作默认只修改已打开的编辑器标签页,不会自动写入磁盘。即使你点了 Replace All,也只在内存中变更,关闭文件前不会落盘:

  • 替换完成后,编辑器左上角标题栏出现圆点(●)表示“有未保存更改”
  • 必须手动按 Ctrl+S(或右键标签页选 Save),或启用自动保存:File > auto Save(推荐设为 afterDelay
  • 若想批量替换并保存所有匹配文件,得先用 Ctrl+Shift+F 搜索,再点击搜索结果列表上方的 Replace in Files 按钮——这个操作才会真正写入文件系统

正则表达式开启后,.* 为什么跨不了行?

VSCode 默认的正则引擎不启用 dotAll 模式(即 . 不匹配换行符),所以 .* 在多行文本中会停在第一个换行处:

  • 解决方法:勾选搜索框左侧的 .* 按钮(正则模式开关旁),它等价于启用 dotAll —— 此时 .* 才能跨行匹配
  • 更安全的写法是显式用 [sS]*(.|n)*,避免依赖 ui 开关状态
  • 注意 $^ 默认是行首/行尾锚点,不是整个文档首尾;如需匹配整个文档开头,用 A,结尾用 Z(VSCode 支持 PCRE 风格的这些锚点)

常用正则实战片段(直接复制粘贴可用)

以下示例均需先点击搜索框左侧的 .* 按钮启用正则:

搜索所有 console.log 调用并删除整行: ^console.log([^)]*);?$  替换成 React 函数组件中的 props 解构(原:function Button(props) {...}): functions+(w+)s*(s*(w+)s*)  → 替换为:const $1 = ({ $2 }) =>

注意 . 在正则中是特殊字符,必须写成 .;括号、花括号也要转义;$1$2 是捕获组引用,不能写成 1

最常被忽略的一点:VSCode 的搜索正则不支持 /(?i) 这类内联标志,大小写敏感与否只能靠点击 Aa 按钮控制——别在正则里写 (?i)abc,它不会生效。

text=ZqhQzanResources