ini配置文件的读写

背景

在安装一些应用程序的时候,我们经常可以其安装目录下看到有 .ini 格式的配置文件,这种格式配置文件是我们比较常见的。在我们自己电脑的系统上也会有,而且还很多。很多系统自带的程序,都会有一个 .ini 格式的配置文件。

为此,Windows还特地提供了相应的WIN32 API函数去对 .ini 格式的配置文件进行读写操作。

函数介绍

// 将一个字符串复制到INI文件的指定的字段中
// 如果函数成功将字符串复制到初始化文件,则返回值不为零。
BOOL WINAPI WritePrivateProfileString(
     _In_ LPCTSTR lpAppName,			// 要复制字符串的字段名称。 
     _In_ LPCTSTR lpKeyName,			// 与字符串关联的键的名称。
     _In_ LPCTSTR lpString,				// 要写入文件的以NULL结尾的字符串
     _In_ LPCTSTR lpFileName			// INI文件的名称
);

// 从INI文件中的指定的字段中获取一个字符串。
// 返回复制到缓冲区的字符数,不包括终止空字符
DWORD WINAPI GetPrivateProfileString(
     _In_  LPCTSTR lpAppName,			// 字段的名称。(NULL 则获取所有内容)
     _In_  LPCTSTR lpKeyName,			// 要检索的键名。
     _In_  LPCTSTR lpDefault,			// 默认字符串。
     _Out_ LPTSTR  lpReturnedString,	// 指向接收检索字符串的缓冲区的指针。
     _In_  DWORD   nSize,				// lpReturnedString参数指向的缓冲区的大小
     _In_  LPCTSTR lpFileName			// INI文件的名称。
);


// 在INI文件中的指定的字段中获取它的整数值
// 返回INI文件中指定键名后的字符串转换后的整数。
UINT WINAPI GetPrivateProfileInt(
     _In_ LPCTSTR lpAppName,			// INI文件中的字段名称。
     _In_ LPCTSTR lpKeyName,			// 	要检索其值的键名
     _In_ INT     nDefault,				// 如果在初始化文件中找不到键名,返回的默认值
     _In_ LPCTSTR lpFileName			// INI文件的名称。 
);

实现过程

首先,我们调用 WritePrivateProfileString 函数创建一个名为Config.ini的INI文件,并添加INFORMATION和OTHER字段;

在INFORMATION字段下,有两个键名分别为name和age的键,其中键名为name中存储的键值是DemonGan,键名为age中存储的键值为18。在OTHER字段中,键名为class的键值为no1。

char szFileName[] = "C:\\Users\\DemonGan\\Desktop\\ReadWriteIniFile_Test\\Debug\\Config.ini";
    // 向INI文件中写入数据
    ::WritePrivateProfileString("INFORMATION", "name", "DemonGan", szFileName);
    ::WritePrivateProfileString("INFORMATION", "age", "18", szFileName);
    ::WritePrivateProfileString("OTHER", "class", "no1", szFileName);

在这里插入图片描述

然后,我们调用 GetPrivateProfileString 函数,读取INI文件中的INFORMATION字段下的name键的数据。

// 从INI文件中读取字符串数据
    char szReturnString[MAX_PATH] = {0};
    ::GetPrivateProfileString("INFORMATION", "name", NULL, szReturnString, MAX_PATH, szFileName);
    printf("name=%s\n", szReturnString);

接着,我们调用 GetPrivateProfileInt 函数,读取INI文件中的INFORMATION字段下的age键的数据。

// 从INI文件中读取整型数据
    int iReturnInt = ::GetPrivateProfileInt("INFORMATION", "age", 0, szFileName);
    printf("age=%d\n", iReturnInt);

对于类似age=18的整型数据的读取,我们除了可以使用 GetPrivateProfileInt 函数读取之外,还可以使用 GetPrivateProfileString 函数去读取,只要将获取的字符串转换为整型就可以了。其中,GetPrivateProfileInt 函数也是先调用获取字符串,然后再转换为整型,所以,GetPrivateProfileInt 函数是对 GetPrivateProfileString 函数的封装和拓展。

纯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、付费专栏及课程。

余额充值