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+匹配数字串,\bfunction\b精确匹配单词function(\b是单词边界) -
捕获组与引用:可用
(...)捕获,$1、$2在“替换”中引用;搜索时也支持(?命名组,方便阅读...) -
忽略大小写:正则模式下默认区分大小写;添加标志
(?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% 的项目内搜索需求都能高效解决。










