ini配置文件

ini配置文件

ini文件是initialization file的缩写,即初始化文件,是widows系统配置文件所采用的存储格式。

文件扩展名: .ini

ini配置文件的后缀名也不一定必须是.ini, 也可以是.cfg, .conf或者是.txt

ini文件格式

ini配置文件由参数, 节, 注解组成

参数(parameter)

以键值对的形式存在

name=value

每个参数都有一个name和一个value,name和value由等号=分隔

节(section)
  1. 所有的键值对都是以节section为单位结合在一起的

  2. 所有的section名称都是独占一行,并且section名字都被方括号包围着[ ]

  3. 在section声明后的所有parameters都属于这个section

  4. 一个section没有明显的结束标识符,一个section的开始就是上一个section的结束

  5. section不能重复,数据通过section去查找,每个seletion下可以有多个key和value的键值对

[section]
注解

comments使用分号表示, 在分号后面的文字,直到该行结尾全部为注解。

;comment ini文件的数据格式例子

例子

[Section1] ;section name
keyname1=value1
keyname2=value2

[Section2] ;section name
keyname3=value3
keyname4=value4

section用来表示一个段落,ini文件可能是项目中共用的,使用section段名来区分不同用途的参数区

;串口配置实例
[port]
portname=COM4
port=4

其他说明

  • 在windows系统中,INI文件很多,最重要的是System.ini , System32.ini 和 Win.ini
  • ini文件主要存放用户所作的选择以及系统的各种参数,用户可用通过修改ini文件,来改变应用程序和系统的很多配置
  • 从windows95开始,在windows系统中推出了注册表的概念,ini文件在windows系统的地位开始下降。注册表可以使程序和系统都把许多参数和初始化信息存放进注册表中。
  • 通常将服务器相关的配置信息写入到ini配置文件,然后ini配置文件的路径通过系统环境变量XXX_CONFIG_PATH来进行动态指定

ini配置文件(python)

python3中自带configparser模块来读取ini文件

import configparser

#文件路径
cfgpath = "cfg.ini"
# 创建管理对象
conf = configparser.ConfigParser()
# 读ini文件
conf.read(cfgpath,encoding="utf-8")     #python3需要加个参数:encoding="utf-8"
# 获取所有的section
sections = conf.sections()
print(sections)  					# 返回list
items = conf.items('serialport')  	# 参数是 section的名称
print(items)  						# list里面对象是元祖
remove
# 删除一个section中的一个item(以键值KEY为标识)
conf.remove_option('serialport', "port")      # 参数  section名   key名
# 删除整个section这一项
conf.remove_section('serialport')
add
# 添加一个section
conf.add_section("serialport")
# 往section添加key和value
conf.set("serialport", "port", "com4")
write

write写入有两种方式

  1. 删除原文件内容,重新写入

    conf.write(open(cfgpath, "w"))  # 删除原文件重新写入
    
  2. 在原文件基础上继续写入内容,追加模式

    conf.write(open(cfgpath, "a"))  # 追加模式写入
    

remove和set方法并没有真正的修改ini文件内容,只有当执行conf.write()方法的时候,才会修改ini文件内容

写入中文的话,需要加上写入的编码格式:encoding=“utf-8”

# 修改section里面的值
conf.set("week", "day", "星期一")  # 写入中文
conf.write(open(cfgpath, "a", encoding="utf-8"))  # a模式 编码格式
python例子
  1. config.ini文件

    [strings] 
    #Mode: train, test, serve配置执行器的工作模式 
    mode = train 
    #配置模型文件的存储路径 
    working_directory = model 
    #配置训练文件的路径 
    dataset_path=train_data/ 
    
    [ints] 
    #配置分类图像的种类数量 
    num_dataset_classes=10 
    #配置训练数据的总大小 
    dataset_size=50000 
    #配置图像输入的尺寸 
    im_dim=32 
    num_channels = 3 
    #配置训练文件的数量 
    num_files=5 
    #配置每个训练文件中的图像数量 
    images_per_file=10000 
    #配置批训练数据的大小 
    batch_size=32 
    
    [floats] 
    #配置Dropout神经元失效的概率 
    rate=0.5 
    
  2. 解析

    import configparser 
    #定义读取配置文件函数,分别读取section的配置参数,section包括ints、floats、strings 
    def get_config(config_file='./config.ini'): 
        parser=configparser.ConfigParser() 
        parser.read(config_file,encoding="utf-8") 
        #获取整型参数,按照key-value的形式保存 
        _conf_ints = [(key, int(value)) for key, value in parser.items ('ints')] 
        #获取浮点型参数,按照key-value的形式保存 
        _conf_floats = [(key, float(value)) for key, value in parser.items ('floats')] 
        #获取字符型参数,按照key-value的形式保存 
        _conf_strings = [(key, str(value)) for key, value in parser.items ('strings')] 
        #返回一个字典对象,包含读取的参数 
        print(_conf_ints)
        return dict(_conf_ints + _conf_floats + _conf_strings) 
    

返回的就是 字典类型

ini配置文件(c语言)

详细可以参考: https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-getprivateprofileint

write
  • WritePrivateProfileString

    BOOL WritePrivateProfileString(
      [in] LPCSTR lpAppName,
      [in] LPCSTR lpKeyName,
      [in] LPCSTR lpString,
      [in] LPCSTR lpFileName
    );
    
    • lpAppName

      节section名

    • lpKeyName

      键值对的键名,如果为NULL,删除整个节

    • lpString

      键值对的值,如果为NULL,对应的键将被删除

    • lpFileName

      ini文件路径及名称

    • 返回值:成功非0,失败0

read
  • GetPrivateProfileInt

    UINT GetPrivateProfileInt(
      [in] LPCTSTR lpAppName,
      [in] LPCTSTR lpKeyName,
      [in] INT     nDefault,
      [in] LPCTSTR lpFileName
    );
    
    • lpAppName 节名
    • lpKeyName 键名
    • nDefault 默认值,如果没找到则返回
    • lpFileName ini文件名
    • 返回键对应的值,失败返回默认值
  • GetPrivateProfileString

    DWORD GetPrivateProfileString(
      [in]  LPCTSTR lpAppName,
      [in]  LPCTSTR lpKeyName,
      [in]  LPCTSTR lpDefault,
      [out] LPTSTR  lpReturnedString,
      [in]  DWORD   nSize,
      [in]  LPCTSTR lpFileName
    );
    
    • lpReturnedString 接收返回数组的buf
    • nSize buf的大小
    • 返回复制到lpReturnedString中的字节数
c例子
  1. 读配置文件

    [strings] 
    mode = train 
    
    [ints] 
    dataset_size=50000 
    
    [floats]
    rate=0.5 
    
    #include <stdio.h>
    #include <windows.h>
    
    int main(){
    	char mode [50];
    	int mode_len =  GetPrivateProfileString(
      			"strings",
      			"mode",
      			NULL,
      			mode,
      			50,
      			"./config.ini"
    	);
    	
    	int dataset_size = GetPrivateProfileInt(
      				"ints",
      				"dataset_size",
      				0,
      				"./config.ini"
    	);
    	printf("mode: %s\r\n",mode);
    	printf("dataset_size: %d\r\n",dataset_size);
    	
    	return 0;
    }
    
  2. 读浮点数

    没有内置读浮点数的函数,需要自己实现一个。

    float GetPrivateProfileFloat(LPCSTR lpAppName,LPCSTR lpKeyName,INT nDefault,LPCSTR lpFileName)
    {
    	float f = nDefault;
    	char strValue[50] = {0};
    
    	GetPrivateProfileString(lpAppName,lpKeyName,"",strValue,50,lpFileName);
    	if(strlen(strValue) != 0){
    		f= (float)atof(strValue);
    	}
    	return f;
    }
    

参考

微软手册: https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-getprivateprofileint

### 关于 INI 文件的概述 INI 文件是一种简单的结构化文本文件,通常用于存储配置设置。这种类型的文件广泛应用于各种操作系统和编程环境中,作为应用程序参数或环境变量的一种持久化方式[^1]。 #### INI 文件格式特点 - **节(Section)**:由方括号包围的一串字符表示,例如 `[section_name]`。 - **键值对(Key-value Pair)**:每一对键值通过等号或者冒号分隔开,形如 `key=value` 或者 `key:value`。 - 注释可以通过井号 (`#`) 或分号 (`;`) 开始,在该行剩余部分会被视为注释内容而不被处理。 #### Python 中解析 INI 文件的方法 Python 提供了一个名为 `configparser` 的标准库来方便地操作 ini 格式的配置文件。下面是一个简单例子展示如何加载并访问其中的数据: ```python from configparser import ConfigParser c = ConfigParser() c.read('example.ini', encoding='utf-8') # 加载指定编码下的 .ini 文件 sections = c.sections() # 获取所有的 section 名称列表 items_in_section = dict(c.items('main')) # 将特定 section 下的所有 key-value 对转换成字典形式 ``` 上述代码片段展示了基本的操作流程,包括创建 `ConfigParser` 实例、读取文件以及获取某个章节内的所有项[^2]。 对于更复杂的场景,比如当遇到多级嵌套结构或是特殊需求时,则可能需要用到第三方扩展库或者其他技术手段来进行更加灵活高效的解析工作[^3]。 #### Shell 脚本中解析 INI 文件的方式 除了在高级语言里有专门设计好的工具外,在 shell 编程环境下也可以借助一些命令组合完成对 ini 文件的部分功能实现。这里给出了一种基于 awk 工具的做法,它能够快速定位到目标字段并提取其对应值: ```bash _readIni=$(awk -F '=' '/'[$SECTION']/{a=1} a==1&&$1~/'$ITEM'/ {print $2; exit}' example.ini) echo $_readIni ``` 这段脚本会查找给定章节中的特定条目,并打印出相应的值。需要注意的是这种方法相对较为原始且不具备通用性,仅适用于某些特定情况下使用[^4]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

暴风雨中的白杨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值