vscode“在文件夹中查找”支持基础语法(如”短语”、-排除、file:过滤)和正则(需勾选,注意双反斜杠、(?i)忽略大小写等),结合使用可高效定位与替换代码。

VSCode 的“在文件夹中查找”(Ctrl+Shift+F / Cmd+Shift+F)支持简洁但功能强大的搜索语法,结合正则表达式能精准定位代码。关键不在于记住所有符号,而在于掌握几个高频、实用的组合。
基础搜索语法:不用正则也能提效
这些语法默认启用,无需勾选“使用正则表达式”:
- 双引号包裹:搜索完整短语,如
"console.log"不会匹配console.log(单独出现的log - 减号排除:在关键词前加
-排除含该词的文件或行,如Error -test.js查找含error但不在test.js中的内容 - 文件名过滤:用
file:限定范围,如file:*.ts只搜 typescript 文件;file:src/ api表示在src/目录下搜api - 路径通配:支持
**(任意层级子目录),如file:**/utils/*.js匹配所有utils文件夹下的 JS 文件
开启正则:勾选 ✅ “使用正则表达式” 后的核心写法
正则开启后,所有搜索内容按 javaScript 正则引擎解析(注意:不是 PCRE,不支持 K 或条件断言等高级特性):
- 基础元字符照常可用:如
d+匹配数字串,function精确匹配单词function(是单词边界) - 捕获组与引用:可用
(...)捕获,$1、$2在“替换”中引用;搜索时也支持(?<name>...)</name>命名组,方便阅读 - 忽略大小写:正则模式下默认区分大小写;添加标志
(?i)开头即可忽略,如(?i)http:// - 多行匹配:默认单行,若需跨行匹配(比如匹配从
if (到})的整个块),需启用(?s)(s= dotall 模式),此时.可匹配换行符
实用技巧:避开常见坑
VSCode 正则有几个易错点,提前知道能省大量调试时间:
- 反斜杠要双写:在搜索框输入
d实际会被当作文本d;必须输d才表示“数字”,因为 VSCode 先做一次字符串解析 - 不支持 Q…E:无法一键转义整个字面量;若想搜索含
.$^的字符串,得手动写成.$^ - 空行匹配小心 ^$:单独搜
^$可能不生效,建议用^s*$(允许空白符)更稳妥 - 替换时保留原内容:用
$&代表整个匹配项,例如把所有console.log(...)改为debugger; // $&
一个真实例子:批量修正过时 API 调用
场景:把 axios.get(url, config) 改为 api.get(url, { ...config })
- 搜索:
axios.get(([^)]+),s*([^)]+))(记得双写反斜杠) - 替换:
api.get($1, { ...$2 }) - 说明:括号用
(转义;[^)]+匹配非右括号内容;s*吃掉可能的空格;$1、$2分别对应两个参数
基本上就这些。不需要背全部正则规则,从 d、b、(?i) 这几个开始用,再配合 file: 和排除语法,90% 的项目内搜索需求都能高效解决。