C++保存配置文件方法之ini文件



一.将信息写入.INI文件中.


1.所用的WINAPI函数原型为: 


BOOL WritePrivateProfileString(
LPCTSTR lpAppName,
LPCTSTR lpKeyName,
LPCTSTR lpString,
LPCTSTR lpFileName
); 


  其中各参数的意义:


   LPCTSTR lpAppName 是INI文件中的一个字段名.


   LPCTSTR lpKeyName 是lpAppName下的一个键名,通俗讲就是变量名.


   LPCTSTR lpString 是键值,也就是变量的值,不过必须为LPCTSTR型或CString型的.


   LPCTSTR lpFileName 是完整的INI文件名.


2.具体使用方法:设现有一名学生,需把他的姓名和年龄写入 c:\stud\student.ini 文件中. 


CString strName,strTemp;
int nAge;
strName="张三";
nAge=12;
::WritePrivateProfileString("StudentInfo","Name",strName,"c:\\stud\\student.ini"); 


   此时c:\stud\student.ini文件中的内容如下:


     [StudentInfo]
     Name=张三


3.要将学生的年龄保存下来,只需将整型的值变为字符型即可:


strTemp.Format("%d",nAge);
::WritePrivateProfileString("StudentInfo","Age",strTemp,"c:\\stud\\student.ini"); 


二.将信息从INI文件中读入程序中的变量.


1.所用的WINAPI函数原型为:


DWORD GetPrivateProfileString(
LPCTSTR lpAppName, 
LPCTSTR lpKeyName, 
LPCTSTR lpDefault, 
LPTSTR lpReturnedString, 
DWORD nSize, 
LPCTSTR lpFileName 
); 


   其中各参数的意义: 


   前二个参数与 WritePrivateProfileString中的意义一样.


   lpDefault : 如果INI文件中没有前两个参数指定的字段名或键名,则将此值赋给变量. 


   lpReturnedString : 接收INI文件中的值的CString对象,即目的缓存器.


   nSize : 目的缓存器的大小.


   lpFileName : 是完整的INI文件名.


  2.具体使用方法:现要将上一步中写入的学生的信息读入程序中.


CString strStudName;
int nStudAge; 
GetPrivateProfileString("StudentInfo","Name","默认姓名",strStudName.GetBuffer(MAX_PATH),MAX_PATH,"c:\\stud\\student.ini"); 


   执行后 strStudName 的值为:"张三",若前两个参数有误,其值为:"默认姓名".


  3.读入整型值要用另一个WINAPI函数: 


UINT GetPrivateProfileInt(
LPCTSTR lpAppName, 
LPCTSTR lpKeyName, 
INT nDefault, 
LPCTSTR lpFileName 
); 


   这里的参数意义与上相同.使用方法如下:
nStudAge=GetPrivateProfileInt("StudentInfo","Age",10,"c:\\stud\\student.ini"); 


补充四点:


   1.INI文件的路径必须完整,文件名前面的各级目录必须存在,否则写入不成功,该函数返回 FALSE 值.


   2.文件名的路径中必须为 \\ ,因为在VC++中, \\ 才表示一个 \ .


   3.也可将INI文件放在程序所在目录,此时 lpFileName 参数为: ".\\student.ini".


   4.从网页中粘贴源代码时,最好先粘贴至记事本中,再往VC中粘贴,否则易造成编译错误,开始时我也十分不解,好好的代码怎么就不对呢?后来才找到这个方法.还有一些代码                  中使用了全角字符如:<,\等,也会造成编译错误.

 

 

三.另外还有一个WriteProfileString和GetProfileString两个方法也是写ini文件的,不过这两个方法没有最后一个参数,而是默认写信息到win.ini文件中

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值