goconfig使用解析
参考:https://github.com/Unknwon/go-rock-libraries-showcases/tree/master/lectures/01-goconfig
goconfig 简介goconfig 是一个由 Go 语言开发的针对 Windows 下常见的 INI 格式的 配置文件解析器。该解析器在涵盖了所有 INI 文件操作的基础上,又针对Go 语言实际开发过程中遇到的一些需求进行了扩展。相对于其它 INI 文件解析器而言,该解析器最大的优势在于 对注释的极佳 支持;除此之外,支持 多个配置文件覆盖加载 也是非常特别但好用的功能。
主要特性提供与WindowsAPI一模一样的操作方式 - 支持递归读取分区支持自增键名支持对注释的读与写操作支持直接返回指定类型的键值 - 支持多个文件覆盖加载
下载安装通过gopm安装:gopm get github.com/Unknwon/goconfig通过goget安装:
go get github.com/Unknwon/goconfig
API文档:GoWalker
基本使用方法加载配置文件:cfg, err := goconfig.LoadConfigFile("conf.ini")
基本读写操作:
value, err := cfg.GetValue(goconfig.DEFAULT_SECTION,"key_default")
isInsert := cfg.SetValue(goconfig.DEFAULT_SECTION,"key_default", "这是新的值”)
注释读写操作:
comment := cfg.GetSectionComments("super")
comment = cfg.GetKeyComments("super", "key_super")
v := cfg.SetKeyComments("super", "key_super", "# 这是新的键注释") v = cfg.SetSectionComments("super", "# 这是新的分区注释")
vInt, err := cfg.Int("must", "int")Must系列方法:
vBool := cfg.MustBool("must", "bool")删除指定键值:
ok := cfg.DeleteKey("must", "string")
保存配置文件:
err = goconfig.SaveConfigFile(cfg, "conf_save.ini")
高级使用方法
多文件覆盖加载:cfg, err := goconfig.LoadConfigFile("conf.ini", "conf2.ini") err = cfg.AppendFiles("conf3.ini")配置文件重载:
err = cfg.Reload()为Must系列方法设置缺省值:
vBool := cfg.MustBool("must", "bool404", true)递归读取键值子孙分区覆盖读取 - 自增键名获取
获取整个分区:
高级使用方法
sec, err := cfg.GetSection("auto increment")
goconfig 包的 API 提供非常全面,用法非常简单,但核心代码并不多,各位 同学有兴趣的可以阅读其源代码。
使用案例:gopm、beego - i18n、beeweb、wetalk、gowalker
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。