iniparser简介


前言

INI文件格式是某些平台或软件上的配置文件的非正式标准,以节(section)和键(key)构成,常用于微软Windows操作系统中。这种配置文件的文件扩展名多为INI,故名。
INI是英文“初始化”(initialization)的缩写。正如该术语所表示的,INI文件被用来对操作系统或特定程序初始化或进行参数设置。
iniparser是一个C语言库,是针对INI文件的开源解析器。

一、ini文件格式

在这里插入图片描述
基本组成单元:key 或者 称之为 property, 每个key都有一个名称(name)和对应的值(value),例如:host = ghcey1O2Yxm.iot-as-mqtt.cn-shanghai.aliyuncs.com
host就是name,ghcey1O2Yxm.iot-as-mqtt.cn-shanghai.aliyuncs.com是value。

可以将多个Key归类为一组,即section。组名定义要独立一行,并用中括号括起来:

[address]
host    =   ghcey1O2Yxm.iot-as-mqtt.cn-shanghai.aliyuncs.com
port    =   1883

其中address就是组名,组成员有hostport

在section声明下的keys都会和该section关联起来。一个section的作用域会在下一个section声明的地方结束,如果没有下section的声明,那么该section的结束地方就是该文件末尾。section是不可以嵌套的。定位一个key是用section:key来表示的,所以不同section下的key的名称是可以相同的。iniparser库处理名称的时候,会统一换成小写,所以section和property的名称命名是大小写无关的。需要注意的是,每个组下的key是唯一的不能重复的,但不同组下可以存在相同key。

注释以分号开头。

二、iniparser

1.下载

Github:https://github.com/ndevilla/iniparser

2.使用方法

git clone https://github.com/ndevilla/iniparser.git
cd iniparser
cd src

在这里插入图片描述
说明:dictionary.h里面声明了一些直接解析ini file的API,iniparser.h里面声明了一些提供用户操作的API。iniparser.h里面的API是对dictionary.h里面API的再次封装,以提供用户友好性。
将这四个文件放入自己的项目中即可。

3.iniparser.h中的API

int iniparser_getnsec(dictionary * d);  //获取dictionary对象的section个数  
char * iniparser_getsecname(dictionary * d, int n); //获取dictionary对象的第n个section的名字  
void iniparser_dump_ini(dictionary * d, FILE * f);  //保存dictionary对象到file  
void iniparser_dumpsection_ini(dictionary * d, char * s, FILE * f); //保存dictionary对象一个section到file   
int iniparser_getsecnkeys(dictionary * d, char * s);    //获取dictionary对象某个section下的key个数  
char ** iniparser_getseckeys(dictionary * d, char * s); //获取dictionary对象某个section下所有的key  
char * iniparser_getstring(dictionary * d, const char * key, char * def);   //返回dictionary对象的section:key对应的字串值  
int iniparser_getint(dictionary * d, const char * key, int notfound);   //返回idictionary对象的section:key对应的整形值  
double iniparser_getdouble(dictionary * d, const char * key, double notfound);  //返回dictionary对象的section:key对应的双浮点值  
int iniparser_getboolean(dictionary * d, const char * key, int notfound);   //返回dictionary对象的section:key对应的布尔值  
int iniparser_set(dictionary * ini, const char * entry, const char * val);  //设置dictionary对象的某个section:key的值  
void iniparser_unset(dictionary * ini, const char * entry); //删除dictionary对象中某个section:key  
int iniparser_find_entry(dictionary * ini, const char * entry) ;    //判断dictionary对象中是否存在某个section:key  
dictionary * iniparser_load(const char * ininame);  //解析dictionary对象并返回(分配内存)dictionary对象  
void iniparser_freedict(dictionary * d);    //释放dictionary对象(内存)  

4.dictionary.h中的API

;地址池
[ipaddrpool]
start                          = 192.168.1.1
end                            = 192.168.1.100
 
[filepath]
leasefile                      = /var/dhcplease/dhcpd.leases
 
;网络接口
[network]
interface                      = en1
 
 [opt]
 dns1                           = 8.8.8.8
 dns2                           = 8.8.8.8
 subnet                         = 255.255.255.0
 router                         = 192.168.3.1
 domain                         = local
 lease                          = 864
 t1                             = 432
 t2                             = 756 


2.test.c

/*********************************************************************************
 *      Copyright:  (C) 2021 lastbreath<2631336290@qq.com>
 *                  All rights reserved.
 *
 *       Filename:  iniparser_test.c
 *    Description:  This file 
 *                 
 *        Version:  1.0.0(10/17/2021)
 *         Author:  lastbreath <2631336290@qq.com>
 *      ChangeLog:  1, Release initial version on "10/17/2021 11:41:52 AM"
 *                 
 ********************************************************************************/

#include <stdio.h>

#include "iniparser.h"

#include "dictionary.h"

#define PATH "./config.ini"



int main (int argc, char **argv)
{
    FILE *fp = NULL;
    dictionary *inip = NULL;
    inip = iniparser_load(PATH);
    if(!inip)
    {
        printf("iniparser_load failure\n");
        return -1;
    }
    int n = iniparser_getnsec(inip);
    if(n)
    {
        for(int i = 0; i < n; i++)
        {
            printf("%s\n",iniparser_getsecname(inip,i));
            int i1 = iniparser_getsecnkeys(inip,iniparser_getsecname(inip,i));
             char *keys[i1];
            char *str = iniparser_getsecname(inip,i);
             iniparser_getseckeys(inip,str,keys);
            char **ptr = keys;
            for(int j = 0; j < i1; j++)
            
            {
                printf("%s\n",*ptr);
                ptr++;
                
            }
        }
    }
    else
    {
        printf("This file has no section!\n");
        return -1;
    }




    iniparser_set(inip,"ipaddrpool:start","192");
    iniparser_set(inip,"ipaddrpool:end","198");
    iniparser_unset(inip,"opt:dns1");

    FILE *fp1 = fopen(PATH,"w");
    iniparser_dump_ini(inip,fp1);
   iniparser_freedict(inip);

    fclose(fp1);

    return 0;
} 


3.makefile

all:
	gcc *.c -o test

run:
	./test

clean:
	rm ./test


4.运行结果截图

在这里插入图片描述

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
纯c读写ini配置文件 用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、付费专栏及课程。

余额充值