VSCode搜索基于ECMAScript 2018+正则引擎,支持^$整行匹配、捕获组替换、\b单词边界、(?s)跨行匹配等技巧,但不支持反向引用替换和\U/\L大小写转换。

VSCode 的搜索功能基于 JavaScript 正则引擎(部分兼容 ECMAScript 2018+),但不支持所有高级特性(比如反向引用在替换中受限、无条件环视需谨慎)。掌握几个关键技巧,能大幅提升查找和重构效率。
用 ^ 和 $ 精准匹配整行
很多人误以为 ^ 和 $ 只在多行模式下才有效——其实在 VSCode 搜索框里,默认就是“多行模式”。这意味着 ^abc$ 能匹配单独一行只有 abc 的内容,而不会匹配 xyz abc def 中的 abc。
- 想删掉所有空行?搜
^$,替换留空即可 - 想找出所有只含数字的行?用
^\d+$ - 注意:VSCode 不把换行符 \n 当作普通字符参与匹配,所以
^$匹配的是“行首到行尾之间无字符”,不是“两个换行符之间为空”
捕获组 + 替换变量,安全重构命名
正则捕获组((...))配合 $1、$2 等变量,是重命名、格式化最实用的组合。VSCode 支持最多 99 个捕获组,且支持非捕获组 (?:...) 来避免干扰编号。
- 把
user_name改成userName:搜(\w+)_(\w+),替换成$1$2不够——要首字母大写?不行,VSCode 不支持\U或\L。但可以分步:先搜_(\w),替换成$1(大写需手动或插件辅助) - 给所有函数调用加日志:搜
(\w+)\(([^)]*)\),替换成console.log('$1'); $1($2) - 小技巧:按 Alt+Enter 可选中所有匹配项,再统一编辑;但正则替换更稳定、可复现
用 \b 避免意外匹配单词片段
\b 是单词边界,匹配位置而非字符。它能防止把 list 错当成 listing 里的子串。
JSON(JavaScript Object Notation) 定义:一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性。业内主流技术为其提供了完整的解决方案(有点类似于正则表达式,获得了当今大部分语言的支持),从而可以在不同平台间进行数据交换。JSON采用兼容性很高的文本格式,同时也具备类似于C语言体系的行为。有需要的朋友可以下载看看
- 搜
list会同时命中list、listing、distlist;搜\blist\b只匹配独立单词 - 注意:
\b基于 \w(字母、数字、下划线)定义边界,所以list-中的list仍会被\blist\b匹配(因为-不是 \w) - 若需更严格控制(比如只认字母边界),可用
(? ——负向先行断言 + 负向后行断言
跨行匹配:用 (?s) 启用单行模式
默认情况下,. 不匹配换行符,导致无法跨行搜索。开启 (?s)(即 dotall 模式)后,. 就能匹配包括 \n 在内的任意字符。
- 想删掉从
/*到*/的多行注释?搜(?s)/\*.*?\*/(记得勾选“正则表达式”和“点号匹配换行符”) - 注意懒惰匹配
.*?,否则会贪婪匹配到文件末尾最后一个*/ - VSCode 也支持
(?m)(多行模式,影响^/$)和(?i)(忽略大小写),可组合使用,如(?si)
基本上就这些。不复杂但容易忽略——尤其 \b 和 (?s),用对了能省下大量手动筛选时间。









