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); }