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