goconfig使用解析

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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

以上是关于goconfig使用解析的主要内容,如果未能解决你的问题,请参考以下文章

GOLANG学习之类库-goconfig

无法使用 eslint-config-airbnb 解析依赖关系树

beego源码解析之配置文件

mybatis学习——config全局配置文件解析

如何使用 Kotlin 在 Android 中处理从 Firebase Remote Config 解析 JSON 的效果方式?

Spring AOP源码—<aop:config/>AOP配置标签解析一万字