Go语言中regexp包支持正则表达式的编译、匹配、替换和提取操作,需先导入包并使用regexp.Compile或regexp.MustCompile编译正则表达式,后者适用于已知正确的正则,前者可处理错误,编译后可复用提高效率;常用方法包括Match判断匹配、FindString获取首个匹配、FindAllString获取全部匹配、FindStringSubmatch提取分组、ReplaceAllString替换匹配内容;语法基于RE2引擎,支持\d表示数字、\w表示字母数字下划线等,不支持后向引用但高效安全。

在Go语言中,regexp 包提供了对正则表达式的支持,能够完成编译、匹配、替换和提取等操作。使用前需要导入 "regexp" 包。由于正则表达式在使用前需要编译,Go推荐使用 regexp.Compile 或 regexp.MustCompile 来创建一个正则对象,之后可多次复用,提高效率。
Go中的正则表达式必须先编译再使用。有两种编译方式:
示例:
r, err := regexp.Compile(`\d+`)
if err != nil {
log.Fatal(err)
}
// 或者使用 MustCompile(仅用于已知正确的正则)
r := regexp.MustCompile(`\d+`)
编译后的 Regexp 对象提供多种方法进行匹配操作:
立即学习“go语言免费学习笔记(深入)”;
示例:
text := "订单号:1001,金额:299元,数量:3件"
r := regexp.MustCompile(`\d+`)
matches := r.FindAllString(text, -1) // -1 表示全部匹配
// 结果:["1001", "299", "3"]
// 提取带分组的信息
r2 := regexp.MustCompile(`订单号:(\d+),金额:(\d+)`)
submatch := r2.FindStringSubmatch(text)
if len(submatch) > 2 {
orderID := submatch[1] // "1001"
amount := submatch[2] // "299"
}
Go的正则语法基于RE2引擎,不支持后向引用等复杂特性,但足够高效和安全。常见模式:
正则编译开销较大,应避免在循环中重复编译。建议将 regexp 对象定义为包级变量或结构体字段,复用实例。
var numRegexp = regexp.MustCompile(`\d+`)
func extractNumbers(text string) []string {
return numRegexp.FindAllString(text, -1)
}
基本上就这些。掌握编译方式和常用匹配方法,就能高效使用Go的正则功能。不复杂但容易忽略的是:优先使用 MustCompile 初始化,运行时用 Match 或 Find 系列方法提取内容。分组匹配时注意 submatch[0] 是完整匹配,从 [1] 开始才是分组。基本上就这些。
以上就是Golang的regexp正则表达式 编译与匹配模式的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号