温馨提示×

Go语言正则表达式如何处理重复模式

小樊
82
2024-11-07 13:17:39
栏目: 编程语言

在Go语言中,使用regexp包处理正则表达式时,可以通过*+?这三个量词来表示重复模式。

  1. *表示匹配前面的子表达式0次或多次。例如,a*表示匹配0个或多个连续的a字符。
package main

import (
	"fmt"
	"regexp"
)

func main() {
	pattern := regexp.MustCompile(`a*`)
	result := pattern.FindString("aaabbbccc")
	fmt.Println(result) // 输出: "aaa"
}
  1. +表示匹配前面的子表达式1次或多次。例如,a+表示匹配1个或多个连续的a字符。
package main

import (
	"fmt"
	"regexp"
)

func main() {
	pattern := regexp.MustCompile(`a+`)
	result := pattern.FindString("aaabbbccc")
	fmt.Println(result) // 输出: "aaa"
}
  1. ?表示匹配前面的子表达式0次或1次。例如,a?表示匹配0个或1个连续的a字符。
package main

import (
	"fmt"
	"regexp"
)

func main() {
	pattern := regexp.MustCompile(`a?`)
	result := pattern.FindString("aaabbbccc")
	fmt.Println(result) // 输出: "a"
}

你还可以使用{m,n}来表示重复模式的次数范围。例如,a{2,3}表示匹配2个或3个连续的a字符。

package main

import (
	"fmt"
	"regexp"
)

func main() {
	pattern := regexp.MustCompile(`a{2,3}`)
	result := pattern.FindString("aaabbbccc")
	fmt.Println(result) // 输出: "aa"
}

注意:在使用{m,n}时,如果m大于n,则匹配0次。例如,a{3,2}表示匹配0个或2个连续的a字符。

0