Golang使用ini库读取配置详情
作者:zhijie 发布时间:2023-07-02 07:46:56
go-ini的分区
go-ini
的多个配置项通过分区(section
)来划分。有默认(空)分区和命名的分区,没有给分区命名就是默认分区,默认分区必须写在任何一个命名分区的上边。每个配置项通过换行来区分。
go-ini的安装
go-ini/ini
是GitHub上的一个代码库,和其他golang库一样,通过golang命令行下载即可,如果下载速度慢可尝试切换代理:go env -w GOPROXY=https://goproxy.cn
下载命令:
go get github.com/go-ini/ini
ini文件的格式
ini文件以分区来划分多块配置,
默认分区必须写在任何一个命名分区的上边,多个配置项用换行符号分割。
读取ini文件的配置项
直接加在ini文件,通过方法读取
使用
ini.load(ini文件路径)
即可。返回一个配置文件结构体指针和错误信息
cfgs, err := ini.Load("./conf/go-conf.ini")
if err != nil {
fmt.Println(err)
}
// cfgs是配置文件的结构体指针
读取命名分区数据:
sp := cfgs.Section()
选择一个分区,返回分区的结构体指针
Key()
是分区结构体的一个方法,读取分区的配置项,返回一个键的结构体指针
val := cfgs.Section("kafka").Key("address").Value()
fmt.Print(val)
// 打印 : 127.0.0.1:9092
读取默认分区数据
默认分区只需要键分区明为空即可:
val := cfgs.Section().key().Value()
val := cfgs.Section("").Key("a").Value()
fmt.Print(val)
// 打印: 122
关于读取到的键结构体指针。可以键值转为多种类型,包括单不限于go的基本数据类型,有两个返回值
Value()
则直接不做换回直接返回,只有一个返回值
// 直接返回值
val := cfgs.Section("").Key("a").Value()
fmt.Print(val)
// 打印: 122
// 返回一个int类型的key值
val,err := cfgs.Section("").Key("a").Int()
if err != nil {
fmt.Print(err)
}
fmt.Print(val)
// 打印: 122
定义结构体来存放配置项,将配置项映射到结构体中
定义与ini配置项匹配的结构体,通过ini.MapTo()
将配置映射到结构体中。
结构体中成员属性必须加上tag
,ini
库通过tap
映射对应的配置项,
type KafkaConfig struct {
// ini用于给ini库做标识
Address string `ini:"address"`
}
type TailConfig struct {
Path string `ini:"path"`
Filename string `ini:"fileName"`
// 如果是结构体,则指明分区名。其他指明配置项即可
Children `ini:"tailfile.children"`
}
type Children struct {
Name string `ini:"name"`
}
type Config struct {
KafkaConfig `ini:"kafka"`
TailConfig `ini:"tailfile"`
}
func main() {
// 先实例化结构体,将指针传入MapTo方法中
var cfg = new(Config)
err := ini.MapTo(cfg, "./conf/go-conf.ini")
if err != nil {
fmt.Print(err)
}
// 取最深的配置项
fmt.Println(cfg.TailConfig.Children.Name)
}
// 运行结果: pp_mode
父子分区
go-ini
有父子分区,但是层级不是很分明。不管是在结构体中还是直接文件操作,操作起来和平级一样的。
您可以在分区名称中使用
.
来表示两个或多个分区之间的父子关系。如果某个键在子分区中不存在,则会去它的父分区中再次寻找,直到没有父分区为止。
就如上个例子中,映射cfg.TailConfig.Children
, tag上标明的是tailfile.children
,这和平级完全是一样的,层级还是通过结构体体现出来的
两份关键代码
main.go
package main
import (
"fmt"
"github.com/go-ini/ini"
)
type KafkaConfig struct {
Address string `ini:"address"`
}
type TailConfig struct {
Path string `ini:"path"`
Filename string `ini:"fileName"`
// 如果是结构体,则指明分区名
Children `ini:"tailfile.children"`
}
type Config struct {
KafkaConfig `ini:"kafka"`
TailConfig `ini:"tailfile"`
}
type Children struct {
Name string `ini:"name"`
}
func main() {
// var cfg = new(Config)
// err := ini.MapTo(cfg, "./conf/go-conf.ini")
// if err != nil {
// fmt.Print(err)
// }
// fmt.Println(cfg.TailConfig.Children.Name)
cfgs, err := ini.Load("./conf/go-conf.ini")
if err != nil {
fmt.Println(err)
}
// val,_ := cfgs.Section("").Key("a").Int()
fmt.Print(val)
}
go-conf.ini
a=122
[kafka]
address = 127.0.0.1:9092
[tailfile]
path = f:/runtime/tmp
fileName = 4.log
[tailfile.children]
name = pp_mode
来源:https://juejin.cn/backend/Go?sort=newest
猜你喜欢
- 描述微软开发的两个动态库存在后门允许用户查看ASP文件源程序和下载整个网站详细随IIS和Frontpage Extention server
- 当你使用UPDATE, INSERT, DELETE语句更新数据的时候,你就改变了两个地方的数据:log buffer和data buffe
- 上传问题可以说是网络编程中经常遇到的,也是一个很重要的问题,我们不仅要实现上传文件,图片等基本功能,还有考虑到上传程序的安全性,本文介绍了一
- 当你要使用data URI scheme的时候,你会发现,虽然他可以使用在绝大多数浏览器上,但无法再IE6和IE7上工作。不过值得庆幸的这一
- 当where子句对某一列使用函数时,除非利用这个简单的技术强制索引,否则Oracle优化器不能在查询中使用索引。通常情况下,如果在WHERE
- 当你需要一个简单易用的导航菜单得时候。CSS Menu是个不错的选择。相对于Flash/Javascript,他们小巧轻便,而且方便使用。当
- 主要代码如下: total = application("All
- 对于中小型个人、企业网站来说,MySQL数据库或许是目前数据库的最完美实施解决方案了。在不变更服务器硬件的前提下,一个经过良好架构,优化后的
- 文件:.wmv;大小:19,535KB;长度:00:26:39。 下载地址:SqlFunction_udf_Week.rar以下内容于201
- 原理:第一步:应用程序把查询SQL语句发给服务器端执行。我们在数据层执行SQL语句时,应用程序会连接到相应的数据库服务器,把SQL语句发送给
- asp使用WScript.Shell获取电脑的网络配置信息Option Explicit Dim WSHShe
- 因AJAX接受数据时服务器默认是采用UTF-8的编码形式进行传送,所以在很多GB2312中文网页中应用AJAX回传数据经常会发生中文乱码。解
- <% dim conn,mdbfile mdbfile=server.mappath("数据库名称.mdb") s
- 用mysqldump和source可以使用这种方式导出数据:mysqldump -urott -P5678 --default-charac
- 一段重用很高的ajax代码,可以套用 <!DOCTYPE HTML
- 数据库的选择原则是什么?我只知道小网站用Access,大网站用SQL,请问它的具体选择原则是什么?在实际应用中,数据库的选择原则一般是:如果
- CSS代码更清晰高效的一些经验是许多网页制作者与开发者都关心的问题。但是大概没有什么魔法,可以保证一下就把你的样式表缩小到百分之多少,合理的
- 在静态页面里需要显示浏览次数的地方加上这个:浏览次数:<SCRIPT language='javascript
- 1、单个关键字加亮代码: <div id="txt"> 用JS让文章内容指定
- 要实现的SQL查询很原始:要求从第一个表进行查询得到第二个表格式的数据,上网查询之后竟然能写出下面的SQL:代码如下:select * fr