- Created by 郭强, last modified on Jul 27, 2023
You are viewing an old version of this page. View the current version.
Compare with Current View Page History
Version 14 Current »
以下常用方法列表,文档更新可能滞后于代码新特性,更多的方法及示例请参考代码文档:https://pkg.go.dev/github.com/gogf/gf/v2/text/gregex
当函数名中有
All
的时候,它会继续查找非重叠的后续并返回slice
当函数名中有
String
的时候,参数及返回值都是string
,否则为[]byte
IsMatch/IsMatchString
- 说明:
IsMatch()
方法可以测试字符串,判断是否匹配正则表达式的模式。如果发现一次匹配,该方法返回true
,否则返回false
。 格式:
IsMatch(pattern string, src []byte) bool IsMatchString(pattern string, src string) bool
- Tip:
regexp
已经在底层处理并缓存了Regex
对象,以极大地提高执行效率,无需每次显式重新创建,下同。 示例:
func ExampleIsMatch() { patternStr := `\d+` g.Dump(gregex.IsMatch(patternStr, []byte("hello 2022! hello GoFrame!"))) g.Dump(gregex.IsMatch(patternStr, nil)) g.Dump(gregex.IsMatch(patternStr, []byte("hello GoFrame!"))) // Output: // true // false // false }
Match/MatchString
- 说明:用来匹配子字符串,
Match
只返回第一个匹配的结果。区别于原生的正则方法,gregex
是对FindSubmatch
进行封装,直接返回第一个包括子模式结果的slice
。 格式
Match(pattern string, src []byte) ([][]byte, error) MatchString(pattern string, src string) ([]string, error)
示例:匹配
url
中的参数。func ExampleMatch() { patternStr := `(\w+)=(\w+)` matchStr := "https://goframe.org/pages/viewpage.action?pageId=1114219&searchId=8QC5D1D2E!" // This method looks for the first match index result, err := gregex.Match(patternStr, []byte(matchStr)) g.Dump(result) g.Dump(err) // Output: // [ // "pageId=1114219", // "pageId", // "1114219", // ] // <nil> }
MatchAll/MatchAllString
- 说明:用来匹配子字符串,
MatchAll
返回全部的结果。区别于原生的正则方法,gregex
的MatchAll
是对FindAllSubmatch
方法进行封装,返回所有结果集的slice
,包括结果集中的子模式的结果。 格式:
MatchAllString(pattern string, src string) ([][]string, error) MatchAll(pattern string, src []byte) ([][][]byte, error)
示例:下面这个例子是匹配
url
中的参数。func ExampleMatchString() { patternStr := `(\w+)=(\w+)` matchStr := "https://goframe.org/pages/viewpage.action?pageId=1114219&searchId=8QC5D1D2E!" // This method looks for the first match index result, err := gregex.MatchString(patternStr, matchStr) g.Dump(result) g.Dump(err) // Output: // [ // "pageId=1114219", // "pageId", // "1114219", // ] // <nil> }
Quote
- 说明:将指定正则表达式中的特定符号进行转义。
格式:
Quote(s string) string
示例:
func ExampleQuote() { result := gregex.Quote(`[1-9]\d+`) g.Dump(result) // Output: // "\[1-9\]\\d\+" }
Replace/ReplaceString
- 说明:用来替换所有匹配的字符串并返回一个源字符串的拷贝。
格式:
Replace(pattern string, replace, src []byte) ([]byte, error) ReplaceString(pattern, replace, src string) (string, error)
示例
func ExampleReplace() { var ( patternStr = `\d+` str = "hello GoFrame 2020!" repStr = "2021" result, err = gregex.Replace(patternStr, []byte(repStr), []byte(str)) ) g.Dump(err) g.Dump(result) // Output: // <nil> // "hello GoFrame 2021!" }
ReplaceFunc/ReplaceStringFunc
- 说明:用来替换所有匹配的字符串,返回一个源字符串的拷贝。与
Replace
方法的区别在于,该方法可以在闭包中对查询进行二次判断或处理,而非简单的替换。 格式:
ReplaceFunc(pattern string, src []byte, replaceFunc func(b []byte) []byte) ([]byte, error) ReplaceStringFunc(pattern string, src string, replaceFunc func(s string) string) (string, error)
示例:
func ExampleReplaceFunc() { var ( patternStr = `(\d+)~(\d+)` str = "hello GoFrame 2018~2020!" ) // In contrast to [ExampleReplace] result, err := gregex.ReplaceFunc(patternStr, []byte(str), func(match []byte) []byte { g.Dump(match) return bytes.Replace(match, []byte("2020"), []byte("2023"), -1) }) g.Dump(result) g.Dump(err) // ReplaceStringFunc resultStr, _ := gregex.ReplaceStringFunc(patternStr, str, func(match string) string { g.Dump(match) return strings.Replace(match, "2020", "2023", -1) }) g.Dump(resultStr) g.Dump(err) // Output: // "2018~2020" // "hello gf 2018~2023!" // ReplaceFunc result // <nil> // "2018~2020" // "hello gf 2018-2023!" // ReplaceStringFunc result // <nil> }
ReplaceFuncMatch/ReplaceStringFuncMatch
ReplaceFuncMatch
返回src
的拷贝,其中regexp
的所有匹配都被应用于匹配字节切片的函数的返回值替换。 返回的替换直接替换。
- 说明:用来替换所有匹配的字符串,返回一个源字符串的拷贝。该方法的强大之处在于可以在闭包中对查询进行二次判断或处理,且
MatchString
函数包含了所有子模式的查询结果,而非简单的替换。 格式:
ReplaceFuncMatch(pattern string, src []byte, replaceFunc func(match [][]byte) []byte) ([]byte, error) ReplaceStringFuncMatch(pattern string, src string, replaceFunc func(match []string) string) (string, error)
示例:
func ExampleReplaceStringFuncMatch() { var ( patternStr = `([A-Z])\w+` str = "hello Golang 2018~2021!" ) // In contrast to [ExampleReplaceFunc] // the result contains the `pattern' of all subpatterns that use the matching function result, err := gregex.ReplaceFuncMatch(patternStr, []byte(str), func(match [][]byte) []byte { g.Dump(match) return []byte("GoFrame") }) g.Dump(result) g.Dump(err) // ReplaceStringFuncMatch resultStr, err := gregex.ReplaceStringFuncMatch(patternStr, str, func(match []string) string { g.Dump(match) match[0] = "Gf" return match[0] }) g.Dump(resultStr) g.Dump(err) // Output: // [ // "Golang", // "G", // ] // "hello GoFrame 2018~2021!" // ReplaceFuncMatch result // <nil> // [ // "Golang", // "G", // ] // "hello Gf 2018~2021!" // ReplaceStringFuncMatch result // <nil> }
Split
- 说明:将文本内容由指定的正则表达式进行切割。不包含元字符,相当于
strings.SplitN
。 格式:
Split(pattern string, src string) []string
示例:
func ExampleSplit() { patternStr := `\d+` str := "hello2020GoFrame" result := gregex.Split(patternStr, str) g.Dump(result) // Output: // [ // "hello", // "GoFrame", // ] }
Validate
- 说明:基于原生方法
compile
封装,检查给定的正则表达式是否有效 格式:
Validate(pattern string) error
示例:
func ExampleValidate() { // Valid match statement g.Dump(gregex.Validate(`\d+`)) // Mismatched statement g.Dump(gregex.Validate(`[a-9]\d+`)) // Output: // <nil> // { // Code: "invalid character class range", // Expr: "a-9", // } }
Content Menu
- No labels