Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >配置文件格式 INI 快速上手

配置文件格式 INI 快速上手

作者头像
恋喵大鲤鱼
发布于 2024-07-21 23:58:56
发布于 2024-07-21 23:58:56
47800
代码可运行
举报
文章被收录于专栏:C/C++基础C/C++基础
运行总次数:0
代码可运行

1.简介

INI 的全称是 Initialization,即为初始化文件,最早是 Windows 系统配置文件所采用的格式。

有时候,INI 文件也会以不同的扩展名出现,如 .cfg、.conf、或 .txt。但为了可读性,不建议这么做。

因为 INI 并没有一个统一的官方标准,所以这里介绍常见的 INI 文件格式惯例。

2.语法

INI 是一种简单实用且应用广泛的配置文件格式,通常由节、键值对和注释组成。

节(Section)是键值对的分组。

一般情况下,节是可选的,不属于任何节的配置项属于全局配置项。

所有的 Section 名称都是独占一行,并且 Section 名字都被方括号 [] 包围。在 Section 声明后的所有键值对都属于该 Section。一个 Section 没有明显的结束标识符,一个 Section 的开始就是上一个 Section 的结束。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[section]

注意,不同节之间的变量可以同名。

正因为没有显式的“节结束符”(例如 XML</tag>)。因此,节在语法上不能任意嵌套。必要时,可以将层次结构扁平化,使用分隔符分隔多个节名(通常使用点 . 分隔)来实现嵌套。一级嵌套通常是支持的,称为子节。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[section]
domain = example.com

[section.subsection]
foo = bar

键值对

每一个键值对表示一项配置,键与值使用等号分隔。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
name=value

注释

注释以分号(;)开头,有一些 INI 管理器也支持使用井号(#)来注释。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
; this is comment text

大小写

Windows 中的节和键名是不区分大小写的。大多数 Unix 风格的 INI 解析器也完全不区分大小写。

尽管部分 INI 解析器是支持大小写的,但为了良好的可读性,不建议这么做。

空白行

空白行通常被忽略,可以用来提高可读性。

数据类型

INI 文件格式的设计非常简单,不像 YAML、TOML 等更现代的配置文件格式那样明确支持多种数据类型。通常,INI 文件中的所有数据都是以字符串的形式存储的。然而,不同的解析器可能会尝试根据内容自动识别并转换数据类型。

字符串 (String)

默认情况下,所有值都被视为字符串。字符串值可以包含任何字符。

字符串值通常不需要引号,但在某些情况下可以使用引号(单引号或双引号)括起来。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
key1=value1
key2=some text with spaces
key3="quoted string"
整数 (Integer)

一些解析器会尝试将纯数字的值解析为整数。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
key1=42
key2=-3
浮点数 (Float)

类似地,包含小数点的数字可能会被解析为浮点数。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[Section]
key1=3.14
key2=-0.001
布尔值 (Boolean)

常见的布尔值表示法包括 true, false, yes, no, 1, 和 0。许多解析器会自动将这些值转换为布尔类型。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
key1=true
key2=no
key3=1
key4=0
列表 (List)

虽然 INI 文件格式本身不直接支持列表,但可以通过使用分隔符(如逗号或分号)来模拟列表。某些解析器可以将这些值分割成列表。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
key1=value1,value2,value3
key2=item1;item2;item3

3.示例

由于没有官方标准,建议在使用 INI 文件时遵循你所使用的解析器的具体规范,并保持文件结构的简单和一致。

以下是一个综合示例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
; Global section settings
globalKey1=value1

[Section1]
# Section1 specific settings
key1=value1
key2=value2

[Section2]
key1=value3  # Section2 specific settings
key3=value4

4.解析

下面是一个使用键值对表示的后台服务配置。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
; server basic conf
[server]
name=UserProfileServer
maxconns=10000
queuecap=10000
queuetimeout=300

# log conf
[log]
loglevel=ERROR
logsize=10M
lognum=10
logpath=/usr/local/app/log

在解析上面的配置时,可以按行读取,然后放到 map 中。

下面以 Go 为例,完成对上面配置文件的解析。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package main

import (
	"bufio"
	"errors"
	"fmt"
	"io"
	"os"
	"strings"
)

func ParseConf(confPath string) (map[string]string, error) {
	if confPath == "" {
		return nil, errors.New("param is ill")
	}

	f, err := os.Open(confPath)
	if err != nil {
		return nil, err
	}
	defer f.Close()

	// store config info
	m := make(map[string]string)

	bfRd := bufio.NewReader(f)
	// read by line, the line terminator is '\n'
	for {
		line, err := bfRd.ReadString('\n')
		if err == io.EOF {
			return m, nil
		}
		if err != nil {
			return nil, err
		}
		// ignore blank line
		if strings.TrimSpace(line) == "" {
			continue
		}
		// ignore comment line
		if strings.TrimSpace(line)[0] == ';' || strings.TrimSpace(line)[0] == '#' {
			continue
		}
		// ignore section line
		if strings.TrimSpace(line)[0] == '[' {
			continue
		}
		kv := strings.Split(strings.TrimSpace(line), "=")
		if len(kv) == 2 {
			m[kv[0]] = kv[1]
		}
	}
}

func main() {
	conf, _ := ParseConf("server.ini")
	for k, v := range conf {
		fmt.Printf("%v=%v\n", k, v)
	}
}

运行结果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
name=UserProfileServer
maxconns=1000
queuecap=10000
queuetimeout=300
loglevel=ERROR
logsize=10M
lognum=10

推荐使用专业的第三方库来完成 INI 的解析,比如 Golang 中强大的 spf13/viper

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package main

import (
	"fmt"

	"github.com/spf13/viper"
)

func main() {
	// 设置配置文件的名称和路径
	viper.SetConfigName("server.ini") // 可以不写文件扩展名
	viper.AddConfigPath("..")         // 在当前目录查找配置文件

	// 设置配置文件类型为 INI
	viper.SetConfigType("ini")

	// 读取配置文件
	if err := viper.ReadInConfig(); err != nil {
		fmt.Printf("Error reading config file, %s", err)
		return
	}

	// 获取配置项的值
	fmt.Println("server.name:", viper.GetString("server.name"))
	fmt.Println("server.maxconns:", viper.GetInt("server.maxconns"))
	fmt.Println("server.queuecap:", viper.GetInt("server.queuecap"))
	fmt.Println("server.queuetimeout:", viper.GetInt("server.queuetimeout"))

	fmt.Println("log.loglevel:", viper.GetString("log.loglevel"))
	fmt.Println("log.logsize:", viper.GetString("log.logsize"))
	fmt.Println("log.lognum:", viper.GetInt("log.lognum"))
	fmt.Println("log.logpath:", viper.GetString("log.logpath"))
}

运行结果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
server.name: UserProfileServer
server.maxconns: 10000
server.queuecap: 10000
server.queuetimeout: 300
log.loglevel: ERROR
log.logsize: 10M
log.lognum: 10
log.logpath: /usr/local/app/log

参考文献

INI file - wikipedia Apache Documentation for org.apache.commons.configuration2.INIConfiguration

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-07-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Go 译文之词法分析与解析 Part Three
最近发现我的翻译是越来越随性了,刚开始文章翻译的时候比较拘束,现在更多强调可读性,比如有些对文章大意没有什么影响的文字我现在都会选择直接跳过。
波罗学
2020/10/15
4010
Go viper 配置文件读取工具
viper 提供默认 Viper对象, 可直接使用。 也通过 New 方法创建自定义Viper
copy_left
2020/08/11
1.8K0
配置文件格式 XML 快速上手
XML 文档结构是一种树结构,它从“根部”开始,然后扩展到“枝叶”。XML 文档必须有一个唯一的根结点,根结点包含所有其它结点。所有结点均可拥有文本内容和属性(名称/值的对)。XML 结点也叫做 XML 元素。
恋喵大鲤鱼
2024/07/21
1370
配置文件格式 JSON 快速上手
JSON(JavaScript Object Notation) 是轻量级的文本数据交换格式,独立于语言,具有自我描述性。JSON 类似于 XML,但比 XML 更小、更快,更易解析。
恋喵大鲤鱼
2024/07/21
1490
配置文件格式 TOML 快速上手
GitHub 联合创始人 Tom Preston-Werner 觉得 YAML 不够简洁优雅,如缩进要严格对齐,因此和其他几位开发者一起捣鼓了一个 TOML(Tom’s Obvious Minimal Language)。
恋喵大鲤鱼
2024/04/20
1.1K0
程序常用配置文件格式介绍
不管是移动应用、桌面程序还是后台服务,经常需要从配置文件中读取配置信息,进行程序初始化和改变运行时的状态。以什么要的格式来存储配置信息,这是开发人员需要面临的一个问题。常用的配置文件格式主要有:
恋喵大鲤鱼
2022/05/09
3.3K0
程序常用配置文件格式介绍
Go每日一库之6:viper
上一篇文章介绍 cobra 的时候提到了 viper,今天我们就来介绍一下这个库。
luckpunk
2023/09/13
3480
go库介绍:Golang中的Viper库
在Golang(Go)的开发中,配置管理是一个不可或缺的部分。一个优雅的配置管理方案不仅能够简化应用程序的配置处理流程,还能提高应用程序的灵活性和可维护性。在这方面,Viper库无疑是Go生态系统中的一颗璀璨明珠。本文将详细介绍Viper库及其使用场景,并通过具体示例展示其强大功能。
每周聚焦
2024/11/08
4010
go库介绍:Golang中的Viper库
go语言简单实现加载ini文件
https://github.com/lu569368/Practise_reflex/
仙士可
2022/01/27
4680
go语言简单实现加载ini文件
配置文件热加载的go语言实现
通常我们更新应用程序的配置文件,都需要手动重启程序或手动重新加载配置。假设一组服务部署在10台机器上,你需要借助批量运维工具执行重启命令,而且10台同时重启可能还会造成服务短暂不可用。要是更新配置后,服务自动刷新配置多好...今天我们就用go实现配置文件热加载的小功能,以后更新配置再也不用手动重启了...
用户1432189
2018/09/05
8750
配置文件热加载的go语言实现
Go语言(十七) 配置文件库项目
配置文件库项目 简介 用途: 解析ini类型的配置文件 知识点: 主要基于反射 ini配置文件的解析,配置文件如下 ;config file [server] host = www.baidu.com port = 8080 [cartdb] user = root.xxx password = root host = localhost port = 3306 database = cartdb rate = 1.2 需求分析 拆离出动态配置 映射数据到项目数据结构中 -包含配置文件读取(UnMarsh
alexhuiwang
2020/09/23
4450
2.Go语言编程学习课后实践
示例1.利用reflect反射实现一个ini配置文件的读取 (ini 文件解析器)。
全栈工程师修炼指南
2022/09/29
7450
2.Go语言编程学习课后实践
如何读取yaml,json,ini等配置文件【Golang 入门系列九】
本文转载自如何读取yaml,json,ini等配置文件【Golang 入门系列九】 前面已经讲过一些Go语言的基础知识,感兴趣的朋友可以先看看之前的文章。https://www.cnblogs.com/zhangweizhong/category/1275863.html。
ccf19881030
2021/01/04
2.3K0
聊聊kingbus的main.go
kingbus的main方法读取config、version参数,然后通过config.NewKingbusServerConfig(*configFile)获取serverCfg,之后通过server.NewKingbusServer(serverCfg)创建KingbusServer,然后执行ks.Run()
code4it
2020/06/12
3610
聊聊kingbus的main.go
GoLang 环境变量与配置
配置文件是一个 ini 文件。Service 下的 Environment/EnvironmentFile 配置环境变量相关的内容。
闻说社
2024/06/12
1660
GoLang 环境变量与配置
知识分享之Golang——和我一起搭建一个快速开发框架(二)
知识分享之Golang篇是我在日常使用Golang时学习到的各种各样的知识的记录,将其整理出来以文章的形式分享给大家,来进行共同学习。欢迎大家进行持续关注。
cn華少
2021/12/28
3200
知识分享之Golang——和我一起搭建一个快速开发框架(二)
【Go API 开发实战 6】基础 2:配置文件读取
从上面这些特性来看,Viper 毫无疑问是非常强大的,而且 Viper 用起来也很方便,在初始化配置文件后,读取配置只需要调用viper.GetString()、viper.GetInt() 和 viper.GetBool()等函数即可。
腾讯技术工程官方号
2019/05/16
2.1K0
【Go API 开发实战 6】基础 2:配置文件读取
Go每日一库之4:go-ini
ini 是 Windows 上常用的配置文件格式。MySQL 的 Windows 版就是使用 ini 格式存储配置的。
luckpunk
2023/09/12
3420
go语言中的配置管理神器 --viper 一
Viper 是 Go 应用程序的完整配置解决方案,包括 12-Factor 应用程序。它旨在在应用程序中工作,并可以处理所有类型的配置需求和格式。它支持:
onenewcode
2024/02/02
3400
用Go自己实现配置文件热加载功能
说到配置文件热加载,这个功能在很多框架中都提供了,如beego,实现的效果就是当你修改文件后,会把你修改后的配置重新加载到配置文件中,而不用重启程序,这个功能在日常中还是非常实用的,毕竟很多时候,线上的配置文件不是想改就能改的。 这次就自己实现一个配置文件的热加载功能的包,并通过一个简单的例子对完成的包进行使用验证 配置文件热加载包的是实现 其实整体的思路还是比较简单的,当获取配置文件内容后,会开启一个goroutine,去 循环读配置文件,当然这里不可能不限制的一直循环,而是设置了一个定时器,定时去读文件
coders
2018/03/30
1.6K0
用Go自己实现配置文件热加载功能
相关推荐
Go 译文之词法分析与解析 Part Three
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验