登录
首页 >  Golang >  Go问答

GoLang中捕获组的用法指南

来源:stackoverflow

时间:2024-02-06 09:18:23 232浏览 收藏

对于一个Golang开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《GoLang中捕获组的用法指南》,主要介绍了,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

问题内容

我需要使用正则表达式获取 golang 日志,但正则表达式的输出对于“msg”捕获组不正确。我这里有一个函数可以从文件内容中提取日志语句:

func extractlogstatements(content string) []logstatement {
    logpattern := `flog\.(?p.*?)\(\s*flog.(?p.*?),\s*("|fmt.sprintf\(")(?p.*?)"`

    re := regexp.mustcompile(logpattern)
    matches := re.findallstringsubmatch(content, -1)

    logstatements := make([]logstatement, 0, len(matches))
    for _, match := range matches {
        statement := logstatement{
            sev:  match[1],
            type: match[2],
            msg:  match[3],
        }
        logstatements = append(logstatements, statement)
    }

    return logstatements
}

一切正常,除了函数第一行的正则表达式模式没有捕获捕获组的正确值,即使当我在在线正则表达式解析器上测试时它工作正常。

以下是我测试过的日志的一些示例:

flog.info(flog.application, fmt.sprintf("unable to translate address for config: %v", err))

flog.info(flog.application, "unable to translate address for config")

flog.info(flog.application, fmt.sprintf("test 1"),
    lm.crkind, objecttype,
    lm.crname, crname,
    lm.appns, namespace)

对于第一个日志示例,它应该提取“info”(“sev”捕获组)、“application”(“type”捕获组)和“无法转换配置地址:%v”(“msg”捕获组)。当我输出到 json 时,我得到:

[
    {
        "sev": "Info",
        "type": "Application",
        "msg": "fmt.Sprintf(\""
    },
    {
        "sev": "Info",
        "type": "Application",
        "msg": "fmt.Sprintf(\""
    },
    {
        "sev": "Info",
        "type": "Application",
        "msg": "fmt.Sprintf(\""
    },
]

因此,它正确捕获“sev”和“type”捕获组,但对于“msg”,它捕获“fmt.sprintf(””,而它应该得到“无法转换配置的地址:%v”。


正确答案


match[3] 存储组 ("|fmt.sprintf\(") 的值。如果不想捕获,可以使用 ?: 将其变为非捕获组。

(?:"|fmt.sprintf\(")

由于您想要的所有值都由命名捕获组捕获,因此另一种解决方案是按名称引用它们:

for _, match := range matches {
    statement := LogStatement{
        Sev:  match[re.SubexpIndex("sev")],
        Type: match[re.SubexpIndex("type")],
        Msg:  match[re.SubexpIndex("msg")],
    }
    logStatements = append(logStatements, statement)
}

终于介绍完啦!小伙伴们,这篇关于《GoLang中捕获组的用法指南》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>