wego/wini是一款GO语言版本的ini配置文件解析工具,wego/wini具有以下特征:
go get github.com/haming123/wego/wini
首先准备app.conf配置文件:
#应用名称
app_name = demo
#日志级别: 0 OFF 1 FATAL 2 ERROR 3 WARN 4 INFO 5 DEBUG
level = 5
#获取环境变量
go_path = ${GOPATH}
[mysql]
db_name = demodb
db_host = 127.0.0.1:3306
db_user = root
db_pwd = demopwd
接下看看如何读取配置文件,并获取配置项的值:
package main
import (
"fmt"
"github.com/haming123/wego/wini"
)
func main() {
var cfg wini.ConfigData
err := wini.ParseFile("./app.conf", &cfg)
if err != nil {
fmt.Println(err)
return
}
//通过GetXXX获取配置项的值
val := cfg.GetString("app_name")
if val.Error != nil {
fmt.Println( val.Error)
return
}
fmt.Println(val.Value)
}
ini 文件是以分区(section)组织的。分区以[name]开始,在下一个分区前结束。所有分区前的内容属于默认分区([root])。以下代码是section配置项的读取示例:
func TestSectionGet(t *testing.T) {
var cfg wini.ConfigData
err := wini.ParseFile("./app.conf", &cfg)
if err != nil {
t.Error(err)
return
}
//通过GetXXX获取配置项的值
val := cfg.Section("mysql").GetString("db_name")
if val.Error != nil {
t.Error(err)
return
}
t.Log(val.Value)
}
为了方便各种类型的配置数据的获取, wego/wini提供了GetString、GetInt...等函数,例如以下配置文件的读取:
#各种数据类型的配置项
str_value = hello
bool_value = true
int_value = 99
float_value = 123.45
func TestIniGetXXX(t *testing.T) {
var cfg wini.ConfigData
err := wini.ParseFile("./app2.conf", &cfg)
if err != nil {
t.Error(err)
return
}
val := cfg.GetString("str_value")
if val.Error != nil {
t.Error(val.Error)
return
}
t.Log(val.Value)
val_bool := cfg.GetString("bool_value")
if val.Error != nil {
t.Error(val_bool.Error)
return
}
t.Log(val_bool.Value)
val_int := cfg.GetString("int_value")
if val.Error != nil {
t.Error(val_int.Error)
return
}
t.Log(val_int.Value)
val_float := cfg.GetString("float_value")
if val.Error != nil {
t.Error(val_float.Error)
return
}
t.Log(val_float.Value)
}
使用GetXXX函数读取配置项需要进行错误判断,这样的代码写起来会非常繁琐。为此,wego/wini提供对应的MustXXX方法,这个方法只返回一个值,
同时它可接受缺省参数,如果没有配置对应的配置项或配置内容无法转换,则使用缺省值作为返回值。
func TestIniMustXXX(t *testing.T) {
var cfg wini.ConfigData
err := wini.ParseFile("./app2.conf", &cfg)
if err != nil {
t.Error(err)
return
}
t.Log(cfg.MustString("str_value"))
t.Log(cfg.MustBool("bool_value"))
t.Log(cfg.MustInt("int_value"))
t.Log(cfg.MustFloat("float_value"))
}
wego/wini也支持数组类型数据的读取,要求:数组要作为一个配置项添加到ini文件中,并且数组成员之间用指定的分隔符(例如“,”)分隔:
#数组配置项
ints_value = 1,2,3,4,5
func TestGetArray(t *testing.T) {
var cfg wini.ConfigData
err := wini.ParseFile("./app2.conf", &cfg)
if err != nil {
t.Error(err)
return
}
arr, err := cfg.GetInts("ints_value", ",")
if err != nil {
t.Error(err)
return
}
t.Log(arr)
}
wego/wini持通过struct的tag来获取struct字段与配置项的映射关系,并可以通过映射关系自动给struct字段赋值,首先需要在struct定义中指定映射关系:
type DbConfig struct {
MysqlHost string `ini:"db_host"`
MysqlUser string `ini:"db_user"`
MysqlPwd string `ini:"db_pwd"`
MysqlDb string `ini:"db_name"`
}
type AppConfig struct {
AppName string `ini:"app_name"`
HttpPort uint `ini:"http_port;default=8080"`
GoPath string `ini:"go_path"`
DbParam DbConfig `ini:"mysql"`
}
说明:
wego/wini的定义映射关系时支持配置缺省值,再进行数据解析时若没有配置内容,则使用缺省值作为字段的值。
wego/wini使用GetStruct来struct字段赋值,例如:
func TestIniGetStruct(t *testing.T) {
var cfg wini.ConfigData
err := wini.ParseFile("./app.conf", &cfg)
if err != nil {
t.Error(err)
return
}
var data AppConfig
err = cfg.GetStruct(&data)
if err != nil {
t.Error(err)
return
}
t.Log(data)
}
也可以调用Section的GetStruct函数直接从section中获取配置内容,例如:
func TestIniGetSectionStruct(t *testing.T) {
var cfg wini.ConfigData
err := wini.ParseFile("./app.conf", &cfg)
if err != nil {
t.Error(err)
return
}
var data DbConfig
err = cfg.Section("mysql").GetStruct(&data)
if err != nil {
t.Error(err)
return
}
t.Log(data)
}