go 语言运行时获取当前执行的行

在阅读gorm时看到的,记录一下


// 这里的正则需要修改成自己的
var goSrcRegexp = regexp.MustCompile(`gopkg/gorm/.*.go`)
var goTestRegexp = regexp.MustCompile(`gopkg/gorm/.*test.go`)


func fileWithLineNum() string {
	for i := 2; i < 15; i++ {
		_, file, line, ok := runtime.Caller(i)
		if ok && (!goSrcRegexp.MatchString(file) || goTestRegexp.MatchString(file)) {
			return fmt.Sprintf("%v:%v", file, line)
		}
	}
	return ""
}

版权声明:本文为liuYinXinAll原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。