Go-INI - 超赞的Go语言INI文件操作库
bigegpt 2025-05-27 12:46 7 浏览
INI 文件(Initialization File)是十分常用的配置文件格式,其由节(section)、键(key)和值(value)组成,编写方便,表达性强,并能实现基本的配置分组功能,被各类软件框架和项目广泛使用。然而,日渐受到关注的 Go 语言,其官方库并没有对 INI 文件操作的库,而进行 INI 文件的解析也并不是几行就能完成的简单工作。Go-INI,就为 Go 语言添加了对 INI 文件进行读取、解析和写入等操作,使得 Go 项目也能充分利用 INI 文件的便利性。
简介
Go-INI,是 go-ini 在 Github 上开源的 Go 语言 INI 文件操作库,项目位于 https://github.com/go-ini/ini,目前版本为 1.61.0。Go-INIT 功能强大,支持丰富的 INI 语法,功能特性包括:
- 支持覆盖加载多个数据源(file, []byte, io.Reader and io.ReadCloser)
- 支持递归读取键值
- 支持读取父子分区
- 支持读取自增键名
- 支持读取多行的键值
- 支持大量辅助方法
- 支持在读取时直接转换为 Go 语言类型
- 支持读取和 写入 分区和键的注释
- 轻松操作分区、键值和注释
- 在保存文件时分区和键值会保持原有的顺序
- ……
安装
Go-INI 要求 Go 1.6+,使用 go get 安装:
$ go get gopkg.in/ini.v1
示例
我们来看一个简单的使用例子。首先,创建一个 INI 文件 my.ini:
# possible values : production, development
app_mode = development
[paths]
# Path to where grafana can store temp files, sessions, and the sqlite3 db (if that is used)
data = /home/git/grafana
[server]
# Protocol (http or https)
protocol = http
# The http port to use
http_port = 9999
# Redirect to correct domain if host header does not match domain
# Prevents DNS rebinding attacks
enforce_domain = true
这是一个十分常见的 INI 配置文件。然后,我们使用 Go-INIT 来进行操作:
package main
import (
"fmt"
"os"
"gopkg.in/ini.v1"
)
func main() {
cfg, err := ini.Load("my.ini")
if err != nil {
fmt.Printf("Fail to read file: %v", err)
os.Exit(1)
}
// 典型读取操作,默认分区可以使用空字符串表示
fmt.Println("App Mode:", cfg.Section("").Key("app_mode").String())
fmt.Println("Data Path:", cfg.Section("paths").Key("data").String())
// 我们可以做一些候选值限制的操作
fmt.Println("Server Protocol:",
cfg.Section("server").Key("protocol").In("http", []string{"http", "https"}))
// 如果读取的值不在候选列表内,则会回退使用提供的默认值
fmt.Println("Email Protocol:",
cfg.Section("server").Key("protocol").In("smtp", []string{"imap", "smtp"}))
// 试一试自动类型转换
fmt.Printf("Port Number: (%[1]T) %[1]d\n", cfg.Section("server").Key("http_port").MustInt(9999))
fmt.Printf("Enforce Domain: (%[1]T) %[1]v\n", cfg.Section("server").Key("enforce_domain").MustBool(false))
// 修改某个值然后进行保存
cfg.Section("").Key("app_mode").SetValue("production")
cfg.SaveTo("my.ini.local")
}
我们来看一看这段代码做了什么。首先,进行了 Go-INI 的引入:
import "gopkg.in/ini.v1"
然后,使用 Load 接口,进行 INI 文件的打开、加载和解析。Load 的函数定义如下:
func Load(source interface{}, others ...interface{}) (*File, error) {
Load 的 source 参数使用 interface{} 类型,允许多种类型的数据源,包括字符串类型的文件名、[]byte 类型的原数据等。Load 返回一个 *File 类型的文件指针,和一个错误信息。 然后,可以使用 Go-INI 提供的 Section 接口,获取 INI 文件的节:
func (f *File) Section(name string) *Section
再利用 Section 的 Key 接口,实现对于参数值的获取:
func (s *Section) Key(name string) *Key
返回一个 Key 结构体,然后再利用 Key 的 String 接口,获取对应的字符串类型的值:
func (k *Key) String() string
有时候,我们需要对于配置值的值进行验证,当值不在预选列表里时,需要返回一个默认值,而不是一个无效的值。这时,可以使用 Key 的 In 接口实现:
func (k *Key) In(defaultVal string, candidates []string) string
Go-INI 还可以进行值的类型转换:
func (k *Key) MustInt(defaultVal ...int) int
最后,使用 Key 的 SetValue 进行值得设置,然后使用 SaveTo 重新写入文件:
func (k *Key) SetValue(v string)
func (f *File) SaveTo(filename string) error
运行上述代码,我们可以得到以下输出:
$ go run main.go
App Mode: development
Data Path: /home/git/grafana
Server Protocol: http
Email Protocol: smtp
Port Number: (int) 9999
Enforce Domain: (bool) true
此外,Go-INI 还提供了 INI 文件和结构体之间的映射。当配置文件是固定的时候,在代码中定义一个结构体,可以使得对配置的操作更为方便。使用前缀为 ini 的结构体标签,就可以实现 INI 文件和结构体的双向映射:
type Embeded struct {
Dates []time.Time `delim:"|" comment:"Time data"`
Places []string `ini:"places,omitempty"`
None []int `ini:",omitempty"`
}
type Author struct {
Name string `ini:"NAME"`
Male bool
Age int `comment:"Author's age"`
GPA float64
NeverMind string `ini:"-"`
*Embeded `comment:"Embeded section"`
}
func main() {
a := &Author{"Unknwon", true, 21, 2.8, "",
&Embeded{
[]time.Time{time.Now(), time.Now()},
[]string{"HangZhou", "Boston"},
[]int{},
}}
cfg := ini.Empty()
err = ini.ReflectFrom(cfg, a)
// ...
}
总结
Go-INI 作为 Go 语言的 INI 文件操作库,提供了丰富的 INI 文件操作,使得 Go 项目也能应用 INI 配置文件,为大量的已有项目提供了极大的便利,是使用 INI 文件的 Go 项目必备的依赖库。
相关推荐
- php-fpm的配置和优化
-
目录概述php-fpm配置php-fpm进程优化配置慢日志查询配置php7进阶到架构师相关阅读概述这是关于php进阶到架构之php7核心技术与实战学习的系列课程:php-fpm的配置和优化学习目标:理...
- 成功安装 Magento2.4.3最新版教程「技术干货」
-
外贸独立站设计公司xingbell.com经过多次的反复实验,最新版的magento2.4.3在oneinstack的环境下的详细安装教程如下:一.vps系统:LinuxCentOS7.7.19...
- 十分钟让你学会LNMP架构负载均衡
-
业务架构、应用架构、数据架构和技术架构一、几个基本概念1、pv值pv值(pageviews):页面的浏览量概念:一个网站的所有页面,在一天内,被浏览的总次数。(大型网站通常是上千万的级别)2、u...
- php从远程URL获取(mp4 mp3)音视频的流媒体数据
-
/***从远程URL中获取媒体(如mp4mp3)的内容*@parammixed$file_url*@parammixed$media_type...
- Zabbix5.0安装部署
-
全盘展示运行状态,减轻运维人员的重复性工作量,提高系统排错速度,加速运维知识学习积累。1.png1、环境安装关闭SELinux并重启系统2.png安装httpd、mariadb、php运行yum-...
- php 常见配置详解
-
以下是PHP常见的配置项及其含义:error_reporting:设置错误报告级别,可以控制PHP显示哪些错误。例如,设置为E_ALL将显示所有错误,而设置为0将禁止显示任何错误。displa...
- 实践分享|基于基石智算 DeepSeek API + WordPress 插件自动生成访客回复
-
基石智算举办的DeepSeek案例大赛汇集了不少基于CoresHubDeepSeekAPI服务或模型部署服务的精彩实践。本次我们将分享个人实践:通过DeepSeekAPI+Word...
- 如何在Eclipse中搭建Zabbix源码的调试和开发环境
-
Zabbix是一款非常优秀的企业级软件,被设计用于对数万台服务器、虚拟机和网络设备的数百万个监控项进行实时监控。Zabbix是开放源码和免费的,这就意味着当出现bug时,我们可以很方便地通过调试源码来...
- MySQL自我保护参数
-
#头条创作挑战赛#之前(MySQL自我保护工具--pt-kill)提到用pt-kill工具来kill相关的会话,来达到保护数据库的目的,本文再通过修改数据库参数的方式达到阻断长时间运行的SQL的目...
- Python闭包深度解析:掌握数据封装的高级技巧
-
闭包作为Python高级编程特性之一,为开发者提供了一种优雅的方式来实现数据封装和状态保持。这一概念源于函数式编程理论,在现代Python开发中发挥着重要作用。理解和掌握闭包的使用不仅能够提升代码的表...
- Java服务网格故障注入与熔断实战
-
在分布式系统的高可用性挑战中,服务网格的故障注入与熔断机制是检验系统韧性的终极试金石。以下是10道逐步升级的"地狱关卡",每个关卡都对应真实生产环境中可能遇到的致命场景,并附具体场景示...
- MySQL数据库性能优化全攻略:程序员必知的七大核心策略
-
作为程序员,我们每天都要与数据库打交道。当系统用户量突破百万级时,数据库往往成为性能瓶颈的首要怀疑对象。本文将深入探讨MySQL优化的七大核心策略,并提供可直接落地的优化方案,助您构建高效稳定的数据库...
- 如何在 Windows 11 上使用单个命令安装 XAMPP
-
XAMPP是一种广泛使用的软件,用于在Windows操作系统上快速运行LAMP服务器包,包括Windows11。尽管LAMP通常用于Linux系统,但XAMPP并不使用Li...
- uTorrent怎样将bt种子转换为磁力
-
如何用uTorrent把BT种子转为磁力链接?以下方法希望能帮到你。1、在uTorrent窗口里,点击工具栏的按钮,所示。2、在打开窗口里,选取要转为磁力的种子文件,然后点击打开按钮,参照图示操作...
- 支持向量机SVM 分类和回归的实例
-
支持向量机(SupportVectorMachine)是Cortes和Vapnik于1995年首先提出的,它在解决小样本、非线性及高维模式识别中表现出许多特有的优势,并能够推广应用到函数拟合等其他...
- 一周热门
- 最近发表
- 标签列表
-
- mybatiscollection (79)
- mqtt服务器 (88)
- keyerror (78)
- c#map (65)
- resize函数 (64)
- xftp6 (83)
- bt搜索 (75)
- c#var (76)
- mybatis大于等于 (64)
- xcode-select (66)
- mysql授权 (74)
- 下载测试 (70)
- skip-name-resolve (63)
- linuxlink (65)
- httperror403.14-forbidden (63)
- logstashinput (65)
- hadoop端口 (65)
- vue阻止冒泡 (67)
- oracle时间戳转换日期 (64)
- jquery跨域 (68)
- php写入文件 (73)
- kafkatools (66)
- mysql导出数据库 (66)
- jquery鼠标移入移出 (71)
- 取小数点后两位的函数 (73)