参考: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