在没有选择器错误的情况下获取包的使用



我正在使用名为Viper 的配置库

在我的主要内容中,我有这个:

viper.SetConfigName("development")
viper.AddConfigPath("config/settings/")
err := viper.ReadInConfig()
if err != nil {
    fmt.Println("viper config read error %v", err)
}

然后我有一个以毒蛇为参数的结构:

type MyConfig struct {
  v *viper.Viper
}

在我的主界面中,我有一个函数,它返回这个MyConfig,比如:

func NewMyConfig(v *viper.Viper) *MyConfig {
    return &MyConfig{v: v}
}

我得到这个错误:

./main.go:55: use of package viper without selector

不知道我该做什么?

当您导入像这样的包时

import "github.com/spf13/viper"

包名称(在本例中为viper)将作为新标识符提供给您。您可以使用此标识符来构造合格的标识符,以引用包的导出标识符(以大写字母开头的标识符)。

包名称本身不能单独使用。给你错误的行:

myConfig = NewMyConfig(&viper)

您使用了程序包名称viper,但没有指定要从程序包引用的导出标识符。

您希望使用NewMyConfig()函数来获取指向MyConfig结构的新值的指针。NewMyConfig()函数要求值为*viper.Viper。由于viper.Viper结构包含未导出的字段,您可以像&viper.Viper{}一样创建它,但viper包导出一个函数viper.New(),该函数可用于获取指向新的初始化viper.Viper值的指针。你可以像这样使用:

vp := viper.New()
myConfig = NewMyConfig(vp)

请注意,viper包声明了一个内部的、全局的、未导出的viper.Viper"实例"。有许多导出的函数viper.Viper类型的methods匹配。这些"匹配"函数适用于全局的、未导出的viper.Viper实例。因此,您可以选择使用viper包的所有导出全局函数,或者创建自己的Viper实例,然后继续使用其方法。

相关内容

最新更新