纯C读写INI配置文件
描述
本资源文件提供了一个纯C语言编写的INI配置文件读写程序。在C/C++中读写INI配置文件时,常用的第三方开源库如iniparser、libini、rwini、UltraLightINIParser等,往往存在代码量大、功能较弱、接口使用不方便等问题。尤其在大小写处理、前后空格、各种注释、跨平台换行符支持、带引号字符串处理、无section操作、原格式保持等方面存在不足。
本程序由本人精心制作,纯C编写,简洁好用,支持Windows和Linux平台。主要特点如下:
- 支持
;
和#
注释符号,支持行尾注释。 - 支持带引号或成对匹配的字符串,提取时自动去引号。引号中可带其它引号或
;
、#
注释符。 - 支持无section或空section(名称为空)。
- 支持10、16、8进制数,
0x
开头为16进制数,0
开头为8进制。 - 支持section、key或
=
号前后带空格。 - 支持
\n
、\r
、\r\n
或\n\r
换行格式。 - 不区分section、key大小写,但写入时以新串为准,并保持其大小写。
- 新增数据时,若section存在则在该节最后一个有效数据后添加,否则在文件尾部添加。
- 支持指定key所在整行删除,即删除该键值,包括注释。
- 可自动跳过格式错误行,修改时仍然保留。
- 修改时保留原注释:包括整行注释、行尾注释(包括前面空格)。
- 修改时保留原空行。以上三点主要是尽量保留原格式。
不足之处:
- 不支持单key多value(逗号分割),只能一次性提取后自行处理。
- 不支持同名重复section和key。(重复section可视为错误,重复key则可能造成分歧)
- 不能提取所有section或key名称。
使用本程序只需两个文件inirw.h
和inirw.c
,另有测试程序和工程文件,支持Windows和Linux平台。
使用说明
- 将
inirw.h
和inirw.c
文件添加到你的项目中。 - 根据需要调用相关函数进行INI文件的读写操作。
- 测试程序和工程文件可以帮助你快速上手和验证功能。
注意事项
- 本程序不支持单key多value的处理,需要用户自行处理。
- 不支持同名重复section和key,请确保INI文件格式正确。
- 本程序主要用于读写INI配置文件,不提供提取所有section或key名称的功能。
贡献
欢迎提交问题和改进建议,帮助完善本程序。
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考