goconfig简介

goconfig是一个由Go语言开发的针对windows下常见的ini格式的配置文件解析器。该解析器在涵盖了所有ini文件操作的基础之上,又针对Go语言实际开发过程中遇到的一些需求进行了扩展。相对于其他ini文件解析器而言,该解析器最大的优势在于对注释的极佳支持;除此之外,支持多个配置文件覆盖加载也是非常特别但好用的功能。

主要特性

  • 提供与windows API 一模一样的操作方式
  • 支持递归读取分区
  • 支持自增键名
  • 支持对注释的读写操作
  • 支持直接返回指定类型的键值
  • 支持多个文件覆盖加载

下载安装

1:通过gopm安装
gopm get github.com/Unknwon/goconfig
2:通过go get 安装
go get github.com/Unknwon/goconfig

基本使用方法

  • 加载配置文件
cfg, err := goconfig.LoadConfigFile("conf.ini")
if err != nil {
log.Fatalf("无法加载配置文件: %s", err)
}
  • 基本读写操作
value, err := cfg.GetValue(goconfig.DEFAULT_SECTION, "key_default")
if err != nil {
log.Fatalf("无法获取键值(%s): %s", "key_default", value)
}
log.Printf("%s > %s: %s", goconfig.DEFAULT_SECTION, "key_default", value) isInsert := cfg.SetValue(goconfig.DEFAULT_SECTION, "key_default12", "这是新的值")
//如果返回值为false就证明这个setvalue是覆盖原来的值,如果是true,就证明setvalue是创建一个新的键值对
log.Printf("设置键值 %s 为插入操作: %v", "key_default", isInsert)
  • 注释的读写操作
comment := cfg.GetSectionComments("super")
log.Printf("分区 %s 的注释: %v", "super", comment)
//读取super分区的注释 v := cfg.SetSectionComments("super", "# 这是新的分区注释")
log.Printf("分区 %s 的注释被插入或删除: %v", "super", v)
//返回为true 被插入或删除,如果是false表示这个注释是被重写的
  • 类型转换读取
vInt, err := cfg.Int("must", "int")
if err != nil {
log.Fatalf("无法获取键值(%s): %s", "int", err)
}
log.Printf("%s > %s: %v", "must", "int", vInt)
  • Must系列的方法
vBool := cfg.MustBool("must", "bool")
log.Printf("%s > %s: %v", "must", "bool", vBool)
//must系列方法不会返回一个err,当错误发生的时候,默认会返回这个类型的零值
  • 删除指定键值
	ok := cfg.DeleteKey("must", "string")
log.Printf("删除键值 %s 是否成功: %v", "string", ok)
  • 保存配置文件
err = goconfig.SaveConfigFile(cfg, "conf_save.ini")
if err != nil {
log.Fatalf("无法保存配置文件: %s", err)
}

完整代码

package main

import (
"log" "github.com/Unknwon/goconfig"
) func main() {
//有两个返回值,第一个是configfile对象,第二个是一个错误
cfg, err := goconfig.LoadConfigFile("conf.ini")
if err != nil {
log.Fatalf("无法加载配置文件: %s", err)
}
value, err := cfg.GetValue(goconfig.DEFAULT_SECTION, "key_default")
if err != nil {
log.Fatalf("无法获取键值(%s): %s", "key_default", value)
}
log.Printf("%s > %s: %s", goconfig.DEFAULT_SECTION, "key_default", value)
isInsert := cfg.SetValue(goconfig.DEFAULT_SECTION, "key_default12", "这是新的值")
//如果返回值为false就证明这个setvalue是覆盖原来的值,如果是true,就证明setvalue是创建一个新的键值对
log.Printf("设置键值 %s 为插入操作: %v", "key_default", isInsert) comment := cfg.GetSectionComments("super")
log.Printf("分区 %s 的注释: %v", "super", comment) //读取super分区的注释
v := cfg.SetSectionComments("super", "# 这是新的分区注释")
log.Printf("分区 %s 的注释被插入或删除: %v", "super", v) //返回为true 被插入或删除,如果是false表示这个注释是被重写的
vInt, err := cfg.Int("must", "int")
if err != nil {
log.Fatalf("无法获取键值(%s): %s", "int", err)
}
log.Printf("%s > %s: %v", "must", "int", vInt) vBool := cfg.MustBool("must", "bool")
log.Printf("%s > %s: %v", "must", "bool", vBool)
//must系列方法不会返回一个err,当错误发生的时候,默认会返回这个类型的零值 ok := cfg.DeleteKey("must", "string")
log.Printf("删除键值 %s 是否成功: %v", "string", ok)
err = goconfig.SaveConfigFile(cfg, "conf_save.ini")
if err != nil {
log.Fatalf("无法保存配置文件: %s", err)
} }

高级使用方法

  • 多文件覆盖加载
package main

import (
"log" "github.com/Unknwon/goconfig"
) func main() {
cfg, err := goconfig.LoadConfigFile("conf1.ini", "conf2.ini")
//当键值有冲突的时候,以后面加载的配置文件为准
if err != nil {
log.Fatalf("无法加载配置文件: %s", err)
}
value, err := cfg.GetValue("", "key_default")
if err != nil {
log.Printf("无法获取键值(%s): %s", "key_default", err)
return
}
log.Printf("%s > %s: %s", goconfig.DEFAULT_SECTION, "key_default", value)
//追加配置文件
err = cfg.AppendFiles("conf3.ini")
if err != nil {
log.Fatalf("无法追加配置文件: %s", err)
}
}
  • 配置文件重载
//配置文件重载
err = cfg.Reload()
  • 为Must系列方法设置缺省值
vBoot := cfg.MustBool("must", "bool404", true)
//这里404不存在,理应返回false,我们这里将缺省值设置为true
log.Printf("%s > %s: %v", "must", "bool404", vBoot)
  • 递归读取键值
//配置文件内容
; Google
google=www.google.com
search=http://%(google)s //code
val, err := cfg.GetValue("", "search")
if err != nil {
log.Printf("无法获取键值(%s): %s", "search", err)
}
log.Printf("%s > %s : %s", goconfig.DEFAULT_SECTION, "search", val)
//默认会递归的读取键值
//结果是:
2017/10/17 17:01:09 DEFAULT > search : http://www.google.com
  • 子孙分区覆盖读取
//配置文件
[parent]
name=john
relation=father
sex=male
age=32 [parent.child]
age=3
//code
value, err = cfg.GetValue("parent.child", "age")
if err != nil {
log.Printf("无法获取键值(%s): %s", "age", err)
}
log.Printf("%s > %s : %s", "parent.child", "age", value) value, err = cfg.GetValue("parent.child", "sex")
if err != nil {
log.Printf("无法获取键值(%s): %s", "sex", err)
}
log.Printf("%s > %s : %s", "parent.child", "sex", value)
//可以看到在子分区没有得key,它会从父分区读取这个key的值然后进行返回,注意分区命名最好不要包括“ . ”
  • 自增键名获取和获取整个分区
//配置文件是:
; Auto increment by setting key to "-"
[auto increment]
-=hello
-=go
-=config //code
sec, err := cfg.GetSection("auto increment")
if err != nil {
log.Printf("无法获取分区: %s", err)
}
log.Println(sec)
//结果:
2017/10/17 17:16:28 map[#1:hello #2:go #3:config]

goconfig - INI 解析器的更多相关文章

  1. C++ ini解析器

    在gitee上找到的一个很好用的ini文件解析器,纯C++代码,移植方便. 项目地址:https://gitee.com/sollyu/IniParser 稍微修改了下,去掉了Windows平台相关定 ...

  2. golang开发:类库篇(四)配置文件解析器goconfig的使用

    为什么要使用goconfig解析配置文件 目前各语言框架对配置文件书写基本都差不多,基本都是首先配置一些基础变量,基本变量里面有环境的配置,然后通过环境变量去获取该环境下的变量.例如,生产环境跟测试环 ...

  3. Atiit 如何手写词法解析器

    Atiit 如何手写词法解析器 1.1. 通过编程直接从正则->nfa->dfa->表驱动词法解析一条龙自动生成.那是用程序自动生成是需要这样的,自己手写完全不必要这么复杂1 1.2 ...

  4. configparser_配置解析器

    configparser:配置解析器 import configparser config = configparser.ConfigParser() #配置文件 config[', 'Compres ...

  5. $Django Rest Framework-频率组件,解析器

    1 频率组件 #自定义组件写频率认证(重点继承BaseThrottle) from rest_framework.throttling import BaseThrottle import time ...

  6. python接口自动化测试 - configparser配置文件解析器详细使用

    configparser简介 ConfigParser模块已在Python 3中重命名为configparser 该模块定义了ConfigParser类. ConfigParser类实现一种基本的配置 ...

  7. Python3-configparser模块-配置文件解析器

    Python3中的configparser模块主要用于处理类似于windows ini 文件结构的配置文件 1.configparser模块提供实现基本配置语言的ConfigParser类 2.配置文 ...

  8. XML技术之DOM4J解析器

    由于DOM技术的解析,存在很多缺陷,比如内存溢出,解析速度慢等问题,所以就出现了DOM4J解析技术,DOM4J技术的出现大大改进了DOM解析技术的缺陷. 使用DOM4J技术解析XML文件的步骤? pu ...

  9. AFN解析器里的坑

    AFN框架是用来用来发送网络请求的,它的好处是可以自动给你解析JSON数据,还可以发送带参数的请求AFN框架还可以监测当前的网络状态,还支持HTTPS请求,分别对用的类为AFNetworkReacha ...

随机推荐

  1. Windows 8创新之路——样章分享

    在电脑里面躺了大约也有半年多的光景了. 在Windows 8.1还有不到一个月的时间里,将这些内容分享出来,也算是对得起自己那段时间的熬夜. 希望大家多提宝贵意见. 谢! 点击标题可浏览SkyDriv ...

  2. curl工具介绍和常用命令

    curl是利用URL语法在命令行方式下工作的开源文件传输工具.它被广泛应用在Unix.Linux发行版中,并且有DOS和Win32.Win64的移植版本.curl是一个利用URL规则在命令行下工作的文 ...

  3. Linux 修改默认的 yum 源

    官方的yum源在国内访问效果不佳. 需要改为国内比较好的阿里的 yum源,因为每次装的时候都得百度,所以这里记录一下. 修改方式: 1)cd /etc/yum.repos.d/ 这个目录下普通用户可能 ...

  4. MapReduce编程解析

    MapReduce编程模型之案例 wordcount 输入数据 atguigu atguiguss sscls clsjiaobanzhangxuehadoop 输出数据 atguigu 2banzh ...

  5. toast js

    参考别人的,自己改写了下,很好用. <!DOCTYPE html> <html lang="zh-CN"> <head> <meta ch ...

  6. Java学习--数组与方法

    1. public class MethodDemo01{ public static void main(String args[]){ printInfo() ; // 调用printInfo() ...

  7. jsp中文乱码解决办法

    一.JSP页面显示乱码 二.表单提交中文时出现乱码 三.数据库连接 大家在JSP的开发过程中,经常出现中文乱码的问题,可能一至困扰着您,我现在把我在JSP开发中遇到 的中文乱码的问题及解决办法写出来供 ...

  8. C#操作数据表中XML格式的数据

    以前还真没有见过数据表中存储XML格式的数据,刚开始听说的时候,还以为是数据表中有XML的字段类型, 再了解,其实也就是字符串类型的,只不过字符串的格式是XML格式的.确实孤陋寡闻!汗... (可添加 ...

  9. WPF放大镜效果

    在做WPF项目中,不止两个项目需要有放大镜功能. 第一个项目是一个手术室的远程示教系统,主要是为了方便专家演示病症时,可以放大图片上的某些部位. 第二个项目是一个工厂的MES项目,其中有个功能是质量预 ...

  10. 配置kali linux

    在7月底的时候,安全加介绍Fireeye出品的 免费恶意软件分析工具FlareVM,还可进行逆向工程和渗透测试 .今天是看到绿盟科技的一篇介绍Kali Linux配置的文章,这个工具也进入了 渗透测试 ...