正则表达式

只包含普通的文本,代表去精确匹配这个文本

.用来匹配一个任意字符

Match

如果是简单模式匹配,使用Match方法便可:

  1. ok, _ := regexp.Match(pat, []byte(searchIn))

可以使用MatchString进行匹配:

  1. ok, _ := regexp.MatchString(pat, searchIn)
  1. func main() {
  2. match, _ := regexp.MatchString("p([a-z]+)ch", "peach")
  3. fmt.Println(match)
  4. //上面我们是直接使用字符串,但是对于一些其他的正则任务,你需要使用 Compile 一个优化的 Regexp 结构体。
  5. r, _ := regexp.Compile("p([a-z]+)ch")
  6. //这个结构体有很多方法。这里是类似我们前面看到的一个匹配测试。
  7. fmt.Println(r.MatchString("peach"))
  8. //这是查找匹配字符串的。
  9. fmt.Println(r.FindString("peach punch"))
  10. //这个也是查找第一次匹配的字符串的,但是返回的匹配开始和结束位置索引,而不是匹配的内容。
  11. fmt.Println(r.FindStringIndex("peach punch"))
  12. //Submatch 返回完全匹配和局部匹配的字符串。例如,这里会返回 p([a-z]+)ch 和 `([a-z]+) 的信息。
  13. fmt.Println(r.FindStringSubmatch("peach punch"))
  14. fmt.Println(r.FindAllStringSubmatch("peach punch pecadc", -1))
  15. //类似的,这个会返回完全匹配和局部匹配的索引位置。
  16. fmt.Println(r.FindStringSubmatchIndex("peach punch"))
  17. //带 All 的这个函数返回所有的匹配项,而不仅仅是首次匹配项。例如查找匹配表达式的所有项。
  18. fmt.Println(r.FindAllString("peach punch pinch", -1))
  19. //All 同样可以对应到上面的所有函数。
  20. fmt.Println("xxx")
  21. fmt.Println(r.FindAllStringSubmatchIndex("peach punch pinch", -1))
  22. //这个函数提供一个正整数来限制匹配次数。
  23. fmt.Println(r.FindAllString("peach punch pinch", 2))
  24. //上面的例子中,我们使用了字符串作为参数,并使用了如 MatchString 这样的方法。我们也可以提供 []byte参数并将 String 从函数命中去掉。
  25. fmt.Println(r.Match([]byte("peach")))
  26. //创建正则表示式常量时,可以使用 Compile 的变体MustCompile 。因为 Compile 返回两个值,不能用语常量。
  27. r = regexp.MustCompile("p([a-z]+)ch")
  28. fmt.Println(r)
  29. //regexp 包也可以用来替换部分字符串为其他值。
  30. fmt.Println(r.ReplaceAllString("a peach", "<fruit>"))
  31. //Func 变量允许传递匹配内容到一个给定的函数中,
  32. in := []byte("a peach")
  33. out := r.ReplaceAllFunc(in, bytes.ToUpper)
  34. fmt.Println(string(out))
  35. }

ReplaceAllString

  1. //利用正则表达式压缩字符串,去除空格或制表符
  2. func compressStr(str string) string {
  3. if str == "" {
  4. return ""
  5. }
  6. //匹配一个或多个空白符的正则表达式
  7. reg := regexp.MustCompile("\\s+")
  8. return reg.ReplaceAllString(str, "")
  9. }