package main; import (
"regexp"
"fmt"
"strings"
) func main() {
//1、过正则来判断字符串是否匹配
if ok, _ := regexp.Match("^[0-9a-zA-Z_]+$", []byte("hello")); ok {
fmt.Println("ok");
} //上面的例子也可以通过MatchString实现
if ok, _ := regexp.MatchString("^[0-9a-zA-Z_]+$", "hello"); ok {
fmt.Println("ok");
} //2、解析正则表达式
//正则表达式如果合法,Compile会返回一个Regexp对象指针,通过该指针可以在任意字符串上进行操作
re, _ := regexp.Compile("[0-9a-zA-Z_]+"); //3、查找正则匹配的字符串
data := "I am a good man"; //Find函数返回匹配的第一个字符串
one := re.Find([]byte(data));
fmt.Println(string(one)); //FindAll函数返回匹配的所有字符串,n小于0返回全部字符串,否则返回指定长度
all := re.FindAll([]byte(data), 2);
//all为长度为2的slice
fmt.Println(string(all[0]));
fmt.Println(string(all[1])); //FindIndex查找匹配的开始位置和结束位置
ix := re.FindIndex([]byte(data));
fmt.Println(ix); //FindAllIndex查找所有匹配的开始位置和结束位置
//n小于0返回全部,否则返回指定长度
all_ix := re.FindAllIndex([]byte(data), -1);
fmt.Println(all_ix);
re2, _ := regexp.Compile("a(.*)g(.*)"); //FindSubmatch查找子匹配项
sub := re2.FindSubmatch([]byte(data));
//第一个匹配的是全部元素
fmt.Println(string(sub[0]));
//第二个匹配的是第一个()里面的
fmt.Println(string(sub[1]));
//第三个匹配的是第二个()里面的
fmt.Println(string(sub[2])); //FindAllSubmatch查找所有子匹配项
all_sub := re2.FindAllSubmatch([]byte(data), 2);
fmt.Println(string(all_sub[0][0]));
fmt.Println(string(all_sub[0][1])); //FindSubmatchIndex用于查找子匹配项的开始位置和结束位置
sub_ix := re2.FindSubmatchIndex([]byte(data));
fmt.Println(sub_ix); //FindAllSubmatchIndex查找所有子匹配项的开始位置和结束位置
//n小于0返回全部,否则返回指定长度
all_sub_ix := re2.FindAllSubmatchIndex([]byte(data), -1);
fmt.Println(all_sub_ix); //4、正则替换
//通过函数进行替换
re3, _ := regexp.Compile("a");
rep := re3.ReplaceAllStringFunc(data, strings.ToUpper);
fmt.Println(rep); //把匹配的所有字符a替换成b
rep2 := re3.ReplaceAllString(data, "b");
fmt.Println(rep2);
}