Go中正则匹配推荐先用regexp.Compile编译再复用MatchString,适合多次匹配;单次可用regexp.MatchString但有性能开销;注意RE2限制、转义规则及锚点使用。
在 Go 中使用 regexp 包做正则匹配,核心是先用 regexp.Compile 编译正则表达式,再调用 MatchString 判断字符串是否匹配。编译一次可复用,性能更好;若只用一次,也可用 regexp.MatchString(内部自动编译)。
适用于需对多个字符串重复匹配同一模式的场景,比如校验一批邮箱、提取日志中的 IP 地址等。编译后的 *regexp.Regexp 对象可安全并发使用。
regexp.Compile 返回正则对象和错误,必须检查错误(空字符串或非法语法会 panic 或返回 error)MatchString 接收字符串,返回 bool 表示是否匹配(注意:是“是否包含该模式”,不是“是否完全等于”)^ 和 $
示例:
package main底层自动调用 Compile 再匹配,简洁但每次调用都重新编译,高频使用时有性能开销。适合脚本、一次性校验等轻量
场景。
立即学习“go语言免费学习笔记(深入)”;
bool 和 error,错误通常来自正则语法错误示例:
matched, err := regexp.MatchString(`[a-z]+@[a-z]+\.[a-z]+`, "user@example.com")Go 的正则引擎基于 RE2,不支持后向断言、非贪婪修饰符(如 .*?)等高级特性,但足够安全且高效。
\\d 表示一个 \d,或用原生字符串 `\d`
MatchString 是子串匹配 —— re.MatchString("hello world", "ello") 返回 true
^\\d{3}-\\d{2}-\\d{4}$
regxp.Compile("["))会返回 error,不可忽略如果需要提取匹配结果,而不是只判断是否匹配,可用 FindString、FindStringSubmatch 或 FindStringSubmatchIndex 等方法。
re.FindString("abc123def") → "123"
re.FindAllString("a1 b22 c333", -1) → []string{"1", "22", "333"}
re.ReplaceAllString("price: $100", "¥$1") → "price: ¥100"
这些方法都基于已编译的 *regexp.Regexp,所以仍建议优先 Compile 复用。