运行环境: go 1.19.1 windows/amd64
问题描述: 通过regexp的MustCompile得到Regexp对象的FindStringSubmatch方法进行分组捕获时,第二个分组获取的值不符合预期。
相关代码
```
REG_SQL_BAK = "CREATE\\s+TABLE\\s+(\\S+)\\s+AS\\s+SELECT.*FROM\\s+.(\\S+)\\s{0,}.*;"
//解析脚本文件
func parseFileContext(filePath string){
//获取备份表设计的原表,备份表名正则规则
reg_sql_bak_group := regexp.MustCompile(`(?i)` + REG_SQL_BAK)
fi, err := os.Open(filePath)
if err != nil {
panic(err)
}
// 创建 Reader
r := bufio.NewReader(fi)
//创建SQLCheckInfo对象
sCheckInfo := vo.SQLCheckInfo{
}
for {
// line, err := r.ReadString('\n')
line, err := r.ReadString(';')
line = strings.TrimSpace(line)
match_bak := reg_sql_bak_group.FindStringSubmatch(line)
if match_bak != nil {
fmt.Println(line)
fmt.Printf("############key:%v,value:%v#############\n",match_bak[2],match_bak[1])
}
}
```
当我需要解析的文本内容包含如下语句:
create table test1 as
select * from test2;
运行结果中第二个分组的值test2少了一个t。相关信息如下
读的脚本文件中的内容
![image.png](https://static.golangjob.cn/230328/5c5748fa85e71b9b9912f19606f137de.png)
运行相关代码后的结果
![image.png](https://static.golangjob.cn/230328/f8d7d371ad5d49087f359ff49930a7eb.png)
有疑问加站长微信联系(非本文作者)