通八洲科技

如何在Golang中使用regexp进行正则匹配_Compile和MatchString示例

日期:2026-01-02 00:00 / 作者:P粉602998670
Go中正则匹配推荐先用regexp.Compile编译再复用MatchString,适合多次匹配;单次可用regexp.MatchString但有性能开销;注意RE2限制、转义规则及锚点使用。

在 Go 中使用 regexp 包做正则匹配,核心是先用 regexp.Compile 编译正则表达式,再调用 MatchString 判断字符串是否匹配。编译一次可复用,性能更好;若只用一次,也可用 regexp.MatchString(内部自动编译)。

使用 regexp.Compile + MatchString(推荐用于多次匹配)

适用于需对多个字符串重复匹配同一模式的场景,比如校验一批邮箱、提取日志中的 IP 地址等。编译后的 *regexp.Regexp 对象可安全并发使用。

示例:

package main
import (
  "fmt"
  "regexp"
)
func main() {
  re, err := regexp.Compile(`\d{3}-\d{2}-\d{4}`) // 匹配社保号格式
  if err != nil {
    panic(err)
  }
  fmt.Println(re.MatchString("123-45-6789")) // true
  fmt.Println(re.MatchString("abc-12-3456")) // false
}

使用 regexp.MatchString(适合单次简单匹配)

底层自动调用 Compile 再匹配,简洁但每次调用都重新编译,高频使用时有性能开销。适合脚本、一次性校验等轻量场景。

立即学习“go语言免费学习笔记(深入)”;

示例:

matched, err := regexp.MatchString(`[a-z]+@[a-z]+\.[a-z]+`, "user@example.com")
if err != nil {
  log.Fatal(err)
}
fmt.Println(matched) // true

常见注意事项

Go 的正则引擎基于 RE2,不支持后向断言、非贪婪修饰符(如 .*?)等高级特性,但足够安全且高效。

扩展:获取匹配内容(不止判断真假)

如果需要提取匹配结果,而不是只判断是否匹配,可用 FindStringFindStringSubmatchFindStringSubmatchIndex 等方法。

这些方法都基于已编译的 *regexp.Regexp,所以仍建议优先 Compile 复用。