go 正则向后引用,获取分组数据不符合预期(第二组少获取了一个字母)

Liz8202 · 2023-03-28 20:41:10 · 2086 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2023-03-28 20:41:10 的主题,其中的信息可能已经有所发展或是发生改变。

运行环境: 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

运行相关代码后的结果 image.png


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2086 次点击  
加入收藏 微博
2 回复  |  直到 2023-03-29 13:09:29
Neightly
Neightly · #1 · 2年之前

image.png

Liz8202
Liz8202 · #2 · 2年之前

非常感谢,自己写的东西有时看半天看不到你这一下就看出来了

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传