linux c 读ini文件操作,Linux-C 编程/文本处理/INI 文件解析器

1. 简介

开源项目 inih ( 1.3K star ):

https://github.com/benhoyt/inih

inih (INI Not Invented Here 的缩写) 是一个简单的用 C 语言编写的 INI 文件解析器。

INI 文件一般用于保存配置信息,它的格式很简单:

在 Linux 系统中也经常能看到 INI 文件:

代码简介

inih 只有几页代码,并且设计紧凑小巧,因此对嵌入式系统非常有用。

它或多或少与 Python 的INI 文件的 ConfigParser 样式兼容,包括 RFC 822样式的多行语法和 name: value 条目。

要使用它,只需给 ini_parse() 一个 INI 文件,它将为每个解析的 name = value 对调用一个回调函数,通过回调函数返回 section,name 和 value 字符串。之所以采用这种方式 ( "SAX style",SAX 是 Simple API for XML的缩写),是因为它在低内存嵌入式系统上运行良好,而且还因为它可以做到 KISS ( Keep it Simple and Stupid)。

用户也可以:

调用 ini_parse_file() 直接从 FILE * 对象进行解析;

调用 ini_parse_string() 从字符串中解析数据;

调用 ini_parse_stream() 以自定义 fgets-style reader 函数去解析自定义数据流;

2. 使用 inih

2.1 测试例子 ini_example.c

定义数据结构:

程序主干:

用户自定义处理函数:

INI 文件:

运行效果:

2.2 更多的编译参数

有 3 种类型的编译参数可用:

Syntax options,用于配置 INI 文件语法,例如指定注释行的字符;

Parsing options,用于配置解析行为,例如解析错误时是否马上停止解析;

Memory options,内存相关的配置,例如最大的行长度 / 使用 heap 还是 stack 来保存行数据;

3. 内部实现

3.1 整体把握

核心代码就是 ini.c 和 ini.h。

分解 ini.c:

4 个公共函数:

5 个私有函数:

剩下的就是一些宏定义,没有任何公共变量和全局私有变量,非常简洁。

3.2 核心 API 的实现

1) ini_parse_stream() 是关键函数,用于解析数据流:

2) ini_parse_stream() 的参数:

ini_reader reader:函数指针,提供了读取一行文本的操作;

void* stream:待解析的文本数;

ini_handler handler:函数指针,指向用户提供的回调函数。

void* user:用于保存解析后的数据;

3) ini_parse_stream() 实现思路:

读取1行数据:

处理1行数据:

去掉行末尾的空格: rstrip();

跳过行首的空格: lskip();

忽略以 ;或# 开始的注释行:

判断是否是 section:

判断是否是键值对:find_chars_or_comment(start, "=:");

调用用户指定的处理函数,一般是用于保存解析到的数据: handler();

更多的源码细节,请各位自行阅读源码吧~~~

4. 参与讨论

关于 Linux C 编程,大家曾经或者希望研究哪些优秀的开源项目?

快来一起讨论吧~

你和我各有一个苹果,如果我们交换苹果的话,我们还是只有一个苹果。但当你和我各有一个想法,我们交换想法的话,我们就都有两个想法了。

对嵌入式系统 (Linux、RTOS、OpenWrt、Android) 和 开源软件感兴趣,关注公众号:嵌入式Hacker。

觉得文章对你有价值,不妨点个在看和赞。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
纯cini配置文件 用c/c++ini配置文件有不少第三方的开源库,如iniparser、libini、rwini、UltraLightINIParser等,但都不理想,往往代码较大、功能较弱、 接口使用不方便。尤其在大小写处理、前后空格、各种注释、跨平台换行符支持、带引号字符串处理、无section操作、原格式保持等方面存在问题。 现将本人精心制作的ini写程序源码奉献给大家,纯c编写,简洁好用。支持windows和linux。 主要特点: 1、支持;和#注释符号,支持行尾注释。 2、支持带引号'或"成对匹配的字符串,提取时自动去引号。引号中可带其它引号或;#注释符。 3、支持无section或空section(名称为空)。 4、支持10、16、8进制数,0x开头为16进制数,0开头为8进制。 5、支持section、key或=号前后带空格。 6、支持\n、\r、\r\n或\n\r换行格式。 7、不区分section、key大小写,但写入时以新串为准,并保持其大小写。 8、新增数据时,若section存在则在该节最后一个有效数据后添加,否则在文件尾部添加。 9、支持指定key所在整行删除,即删除该键值,包括注释。 10、可自动跳过格式错误行,修改时仍然保留。 11、修改时保留原注释:包括整行注释、行尾注释(包括前面空格)。 12、修改时保留原空行。以上三点主要是尽量保留原格式。 不足之处: 1、不支持单key多value(逗号分割),只能一次性提取后自行处理。 2、不支持同名重复section和key。(重复section可视为错误,重复key则可能造成分歧) 3、不能提取所有section或key名称。 使用只需两个文件inirw.h、inirw.c,另有测试程序和工程文件,支持windows和linux

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值