.ini 文件是Initialization File的缩写,即初始化文件,是windows的系统配置文件所采用的存储格式,来配置应用软件以实现不同用户的要求。配置文件有很多种如ini配置文件,XML配置文件,系统注册表等。在早期的windows桌面系统中主要是用ini文件作为系统的配置文件,从win95以后开始转向使用注册表,但是还有很多系统配置是使用INI文件的。其实INI文件就是简单的txt文件,只不过这种txt文件要遵循一定的INI文件格式。

  ini文件由节、键、值组成:


  [section] 参数(键=值)
  name=value 注解
  注解使用分号表示(;)。在分号后面的文字,直到该行结尾都全部为注解。

  ini文件中可以存在多个小节(Section),每个小节的开始用包括在一对方括号中的小节名称指定,不同的小节不能重名,一个小节的内容从小节名称的下一行开始,直到下一个小节开始为止。用户程序可以按照自己的需求建立多个小节。因为ini文件可能是项目中共用的,所以使用[section]来区分不同用途的参数区。例如:[Section1 Name]表示传感器灵敏度参数区;[Section2 Name]表示测量通道参数区等等。INI所包含的最基本的“元素”就是parameter,每一个parameter都有一个name和一个value,name和value是由等号“=”隔开,name在等号的左边。如:name = value

  Windows提供了一系列函数(包含winbase.h或windows.h头文件即可使用)来读写ini文件:

  • 将信息写入.INI文件中
BOOL WritePrivateProfileStringA(
LPCSTR lpAppName, // section name
LPCSTR lpKeyName, // key name.  If this parameter is NULL, the entire section, including all entries within the section, is deleted.
LPCSTR lpString, // string to add. If this parameter is NULL, the key pointed to by the lpKeyName parameter is deleted.
LPCSTR lpFileName // initialization file
); BOOL WritePrivateProfileSectionW( LPCWSTR lpAppName, LPCWSTR lpString, LPCWSTR lpFileName );

  当这些参数全部指定为字符串的时候,函数将在指定INI文件的指定小节中写入“键名=键值”格式的行;当指定的INI文件、文件中的小节和小节中的键名都已经存在的时候,函数用新键值替换原来的键值;当指定的INI文件存在而小节不存在的时候,函数自动创建小节并将键写入;如果连指定的INI文件也不存在的话,函数会自动创建文件。总之,程序不必考虑INI文件是否存在,小节是否存在或键值定义是否存在等情况,只要调用WritePrivateProfileString函数就可以保证配置信息被正确保存。

  WritePrivateProfileString函数也可以用来删除键或者小节,当lpAppName和lpKeyName参数指定了小节名称和键名,而lpString参数指定为NULL的时候,函数将指定的键删除。也可以将lpKeyName和lpString参数全部指定为NULL,而lpAppName参数指定小节名称,那么将会删除lpAppName参数指定的小节。

  注意如果定义了UNICODE使用的函数实际上为WritePrivateProfileStringW。可以使用_T()宏或TEXT()宏:TEXT() 在定义 UNICODE 情况下使用 UNICODE 字符,否则使用 ANSI 字符。

#ifdef UNICODE
#define WritePrivateProfileString WritePrivateProfileStringW
#else
#define WritePrivateProfileString WritePrivateProfileStringA
#endif // !UNICODE
  • 将信息从INI文件中读入程序中的变量
DWORD GetPrivateProfileString(
LPCTSTR lpAppName, // If this parameter is NULL, the GetPrivateProfileString function copies all section names in the file to the supplied buffer.
LPCTSTR lpKeyName, // If this parameter is NULL, all key names in the section specified by the lpAppNameparameter are copied to the buffer specified by the lpReturnedString parameter.
LPCTSTR lpDefault, // If the lpKeyName key cannot be found in the initialization file, GetPrivateProfileString copies the default string to the lpReturnedString buffer.
LPTSTR lpReturnedString, // destination buffer
DWORD nSize, // size of destination buffer
LPCTSTR lpFileName // The name of the initialization file
);

  函数的返回值是返回到缓冲区中的字符串长度。lpReturnedString参数指向一个缓冲区,函数在这里返回获取的键值字符串,缓冲区的长度用nSize参数指定,当缓冲区的长度太小以至于无法容纳返回的字符串时,字符串会被截止到nSize-1的长度后返回,余下的一个字节用来存放一个a null character(0字符:'\0')做结尾。lpDefault参数指向一个默认字符串,当指定的键无法找到的时候,函数将这个字符串拷贝到返回缓冲区中。

  GetPrivateProfileString还有两种特殊用法:

  (1)当lpAppName参数指定为NULL的时候,函数在缓冲区中返回的是全部小节名称的列表,每个小节名以0结尾,全部的名称列表再以一个附加的0结束,返回到缓冲区中的数据格式如下所示:

    小节名称1,0,小节名称2,0,…,小节名称n,0,0

  (2)当lpAppName参数指定了小节名称,而lpKeyName参数指定为NULL的时候,函数在缓冲区中返回该小节的全部键名列表,每个键名以0结尾,全部列表后面再以一个附加的0结束,如下所示:

    键名1,0,键名2,0,…,键名n,0,0

  因此可以用这两种方式来枚举INI文件中的节名以及各个节中的键名。

  下面代码在VS项目目录中创建了一个test.ini的文件:

#include <windows.h>

int main()
{
WritePrivateProfileString(TEXT("Section1"),
TEXT("FirstKey"),
TEXT("Value1"),
TEXT(".\\test.ini")); WritePrivateProfileString(TEXT("Section1"),
TEXT("SecondKey"),
TEXT("Value2"),
TEXT(".\\test.ini")); // Test
TCHAR inBuf[];
int ret = GetPrivateProfileString(TEXT("Section1"),
TEXT("FirstKey"),
TEXT("Error: failed"),
inBuf,
,
TEXT(".\\test.ini"));
_tprintf(TEXT("Key: %s\n"), inBuf); return ;
}

  test.ini文件内容如下: 

[Section1]
FirstKey=Value1
SecondKey=Value2

  GetPrivateProfileString函数获取FirstKey的值Value后将其打印在屏幕上,输出为:

  Key: Value1

  如果将接收数组长度改为3,可以看到结果被截断,GetPrivateProfileString函数返回值为3-1=2:

  当lpKeyName参数指定为NULL的时候,函数在缓冲区中返回该小节的全部键名列表:

  当lpAppName参数指定为NULL的时候,函数在缓冲区中返回的是全部小节名称的列表:

  如果key的值为整数,那么还可以使用GetPrivateProfileInt函数来读取。该函数返回键值对应的整数

UINT GetPrivateProfileInt(
LPCTSTR lpAppName,
LPCTSTR lpKeyName,
INT nDefault, //The default value to return if the key name cannot be found in the initialization file.
LPCTSTR lpFileName
);

  比如下面的ini文件,可以用GetPrivateProfileInt函数获取Section2中AnotherKey的值,将返回整型数字2。如果获取其它section中的键值将返回默认值。

[Section1]
FirstKey=Value1
SecondKey=Value2
[Section2]
AnotherKey=2

  代码如下:

#include <windows.h>

int main()
{ WritePrivateProfileString(TEXT("Section1"),
TEXT("FirstKey"),
TEXT("Value1"),
TEXT(".\\test.ini")); WritePrivateProfileString(TEXT("Section1"),
TEXT("SecondKey"),
TEXT("Value2"),
TEXT(".\\test.ini")); WritePrivateProfileString(TEXT("Section2"),
TEXT("AnotherKey"),
TEXT(""),
TEXT(".\\test.ini")); // Test
TCHAR inBuf[];
int ret = GetPrivateProfileString(TEXT("Section1"),
TEXT("FirstKey"),
TEXT("Error: failed"),
inBuf,
,
TEXT(".\\test.ini"));
_tprintf(TEXT("Key: %s\n"), inBuf); // Get keys in section1
GetPrivateProfileString(TEXT("Section1"), NULL, TEXT("Error: failed"), inBuf, , TEXT(".\\test.ini")); // Retrieves an integer associated with a key in the specified section of an initialization file.
UINT i = GetPrivateProfileInt(TEXT("Section2"), TEXT("AnotherKey"), , TEXT(".\\test.ini"));
printf("integer value: %d", i); return ;
}

参考:

WriteProfileString

INI配置文件的格式

INI文件的操作

在VC++中读写INI文件

VC++ 操作ini库 VS2010

vs2010 操作ini文档,写入和读出内容

UNICODE VS _UNICODE 与 TEXT() VS _T()

Windows中读写ini文件的更多相关文章

  1. 如何在C#中读写INI文件

    INI文件就是扩展名为"ini"的文件.在Windows系统中,INI文件是很多,最重要的就是"System.ini"."System32.ini&q ...

  2. C#中读写INI文件

    C#中读写INI文件 c#的类没有直接提供对ini文件的操作支持,可以自己包装win api的WritePrivateProfileString和GetPrivateProfileString函数实现 ...

  3. C#中读写INI文件

    INI文件就是扩展名为“ini”的文件.在Windows系统中,INI文件是很多,最重要的就是“System.ini”.“System32.ini”和“Win.ini”.该文件主要存放用户所做的选择以 ...

  4. C#在winform中读写ini文件

    class WY_INI { static string IniFileName; static char[] TrimChar = { ' ', '\t' }; public string[] Ge ...

  5. C++ Windows API 读写INI文件

    BOOL WritePrivateProfileString( LPCTSTR lpAppName, // INI文件中的一个字段名[节名]可以有很多个节名 LPCTSTR lpKeyName, // ...

  6. WIN32读写INI文件方法

      在程序中经常要用到设置或者其他少量数据的存盘,以便程序在下一次执行的时候可以使用,比如说保存本次程序执行时窗口的位置.大小.一些用户设置的 数据等等,在 Dos 下编程的时候,我们一般自己产生一个 ...

  7. 读写ini文件

    C# 使用文件流来读写ini文件 背景 之前采用ini文件作为程序的配置文件,觉得这种结构简单明了,配置起来也挺方便.然后操作方式是通过WindowsAPI,然后再网上找到一个基于WindowsAPI ...

  8. 在 WinCe 平台读写 ini 文件

    在上篇文章开发 windows mobile 上的今日插件时,我发现 wince 平台上不支持例如 GetPrivateProfileString 等相关 API 函数.在网络上我并没有找到令我满意的 ...

  9. Qt读写ini文件

    一 背景 1 ini文件介绍 .ini 文件是Initialization File的缩写,即初始化文件. 除了windows现在很多其他操作系统下面的应用软件也有.ini文件,用来配置应用软件以实现 ...

随机推荐

  1. Validation failed for object='employee'. Error count: 1问题解决

    2018-11-13 在表单提交时有时候会提示 Validation failed for object=’user’. Error count: 1,其中user是表的名字,Error count是 ...

  2. 记录一个chrome 65渲染的bug

    前段时间发现一个chrome 65+的BUG(chrome已更新到66,BUG仍然存在),一个元素同时使用了以下样式(失去焦点和css3的Z轴平移0deg),渲染异常 /*bug style*/ fi ...

  3. Spring Boot 静态资源访问原理解析

    一.前言 springboot配置静态资源方式是多种多样,接下来我会介绍其中几种方式,并解析一下其中的原理. 二.使用properties属性进行配置 应该说 spring.mvc.static-pa ...

  4. 熔断器---Hystrix

    Hystrix:熔断器,容错管理工具,旨在通过熔断机制控制服务和第三方库的节点,从而对延迟和故障提供更强大的容错能力. 说到熔断器,先要引入另外一个词,雪崩效应. 雪崩效应,百度百科的解释是这样的: ...

  5. POJ2386----Lake Counting

    /* 利用宽搜将每块积水填满,添加一个计数器,记下填满几块积水即答案 */ #include<iostream> using namespace std; ][]; ][] = {{-,- ...

  6. java菜鸟之微信分享

    前言:我终于理解了什么叫做教科书:教科书就是把一些简单容易的知识写成一堆谁都看不懂的书,这,就简称“教科书” 这些天接触到微信分享以及回调的问题,因为之前没接触过,所以这次做这个分享,碰了一点点壁,特 ...

  7. Spring cloud Eureka错误锦集(一)

    初学Spring cloud的时候,启动Eureka的时候报了下面的错误: com.sun.jersey.api.client.ClientHandlerException: java.net.Con ...

  8. 01 bubbleSort

    #include<cstdio> #include <memory> #include <iostream> using namespace std; void b ...

  9. 2955 ACM 杭电 抢银行 01背包 乘法

    题意: 强盗抢银行,在不被抓住的情况下,想尽量多的偷点钱.已知各个银行的金钱和被抓的概率,以及强盗能容忍的最大不被抓的概率(小于等于该概率才能不被抓),求最多能抢到钱? 并不是简单的01背包问题? 1 ...

  10. go知识点和注意事项

    bin目录下面存的是编译之后可执行的文件,pkg下面存放的是应用包,src下面保存的是应用源代码 Go 语言不支持函数重载特性的主要原因是函数重载需要进行多余的类型匹配影响性能: 目前 Go 没有泛型 ...