为什么80%的码农都做不了架构师?>>>
正则 语法 google/re2
Printf 语法
几个函数方法
名称 | 说明 | 备注 |
Match | 验证正则表达式是否匹配 []byte | - |
MatchString | 验证正则表达式是否匹配 string | - |
FindString | ||
FindStringSubmatch | 返回 []string | 分组 |
FindAllString | Regexp的方法,匹配字符串,返回匹配结果组成一个 []string。限定参数 -1表示不限定,其它表示限定。 | 贪婪模式 |
FindAllStringSubmatch | Regexp的方法,返回一个 [][]string | 贪婪模式, 分组 |
示例
MatchString
func MatchString(pattern string, s string) (matched bool, err error)
matched, err := regexp.MatchString("foo.*", "seafood")
fmt.Println(matched, err)
matched, err = regexp.MatchString("bar.*", "seafood")
fmt.Println(matched, err)
matched, err = regexp.MatchString("a(b", "seafood")
fmt.Println(matched, err)
/*output:
true
false
false error parsing regexp: missing closing ): `a(b`
*/
FindString(非贪婪模式)
func (re *Regexp) FindString(s string) string
re := regexp.MustCompile("fo.?")
fmt.Printf("%q\n", re.FindString("seafood"))
fmt.Printf("%q\n", re.FindString("meat"))
/*output:
"foo"
""
*/
FindStringSubmatch (非贪婪模式,分组)
func (re *Regexp) FindStringSubmatch(s string) []string
re := regexp.MustCompile("a(x*)b(y|z)c")
fmt.Printf("%q\n", re.FindStringSubmatch("-axxxbyc-"))
fmt.Printf("%q\n", re.FindStringSubmatch("-abzc-"))
/*output:
["axxxbyc" "xxx" "y"]
["abzc" "" "z"]
*/
FindAllString(贪婪模式)
func (re *Regexp) FindAllString(s string, n int) []string
re := regexp.MustCompile("a.")
fmt.Println(re.FindAllString("paranormal", -1))
fmt.Println(re.FindAllString("paranormal", 2))
fmt.Println(re.FindAllString("graal", -1))
fmt.Println(re.FindAllString("none", -1))
/*output:
[ar an al]
[ar an]
[aa]
[]
*/
FindAllStringSubmatch(贪婪模式,分组)
func (re *Regexp) FindAllStringSubmatch(s string, n int) [][]string
re := regexp.MustCompile("a(x*)b")
fmt.Printf("%q\n", re.FindAllStringSubmatch("-ab-", -1))
fmt.Printf("%q\n", re.FindAllStringSubmatch("-axxb-", -1))
fmt.Printf("%q\n", re.FindAllStringSubmatch("-ab-axb-", -1))
fmt.Printf("%q\n", re.FindAllStringSubmatch("-axxb-ab-", -1))
/*output:
[["ab" ""]]
[["axxb" "xx"]]
[["ab" ""] ["axb" "x"]]
[["axxb" "xx"] ["ab" ""]]
*/
注:
1)这里的 %q,表示双引号显示。
2)FindAllStringSubmatch 与 FindStringSubmatch 的区别(一个贪婪,一个不贪婪)
re := regexp.MustCompile("a(x*)b")
fmt.Printf("%q\n", re.FindAllStringSubmatch("-ab-axb-", -1))
fmt.Printf("%q\n", re.FindStringSubmatch("-ab-axb-"))
/*output:
[["ab" ""] ["axb" "x"]]
["ab" ""]
*/