当前位置:文档之家› C++ INI配置文件

C++ INI配置文件

DefaultDir=E:\xxx
TIniFile类有几个常用的方法给大家介绍一下:
__fastcall TIniFile(const AnsiString FileName) : Inifiles::TCustomIniFile(FileName) { }
这个方法创建一个INI对象,如果FileName指定的文件名不存在则自动生成此文件,FileName可以用全路径,指定INI文件的地点,如果只有文件名没有路径,这个函数将到Windows系统路径下去打开或创建。(WIN9X是Windows目录,NT和2000是WINNT目录)
---- 2、在Var变量定义部分增加一行:
myinifile:Tinifile;
----然后,就可以对变量myinifile进行创建、打开、读取、写入等操作了。
三、打开INI文件
myinifile:=Tinifile.create('program.ini');
---上面这一行语句将会为变量myinifile与具体的文件program.ini建立联系,然后,就可以通过变量myinifile,来读写program.ini文件中的关键字的值了。
在ini文件中表示如下:
[SearchExtTag]
CONT=0;
想添加其他的key可以依次添加
ExtractFilePath()
ExtractFilePath()
功能:返回完整文件名中的路径
函数原型如下:
AnsiString __fastcall ExtractFilePath;
ExtractFilePath和相近函数:
myinifile.writebool('小节名','关键字',变量或True或False);
----当这个INI文件不存在时,上面的语句还会自动创建该INI文件。
六、删除关键字
----除了可用写入方法增加一个关键字,Tinifile类还提供了一个删除关键字的对象方法:
myinifile.DeleteKey('小节名','关键字');
二、这时创建出来的文件是空的,要往里面写东西,直接调用
ini->WriteInteger("","",);函数
例如ini->WriteInteger("SearchExtTag","CONT",0);这样就在ini文件中生成了,名为SearchExtTag的session,它有一个名为CONT的key,值为0;
这个方法是向INI文件中写入一个字符串,Senction是指定的键,Ident是指定的数据项,Value是要写入的数据。同TRegistry一样,TIniFile类还提供了读取整型、布尔型,二进制等数据类型的读写方法,大家看看联机帮助就可以了,用法基本一样。下面就那上面的INI文件为例来说明一下如何有INI文件来保存配置信息和如何从INI文件中读取数据。
----值得注意的是,如果括号中的文件名没有指明路径的话,那么这个Program.ini文件会存储在Windows目录中,把Program.ini文件存储在应用程序当前目录中的方法是:为其指定完整的路径及文件名。下面的两条语句可以完成这个功能:
Filename:=ExtractFilePath(Paramstr(0))+'program.ini';
七、小节操作
---增加一个小节可用写入的方法来完成,删除一个小节可用下面的对象方法:
myinifile.EraseSection('小节名');
---另外Tinifile类还提供了三种对象方法来对小节进行操作:
--- myinifile.readsection('小节名',TStrings变量);可将指定小节中的所有关键字名读取至一个字符串列表变量中;
--- myinifile.readsections(TStrings变量);可将INI文件中所有小节名读取至一个字符串列表变量中去。
---- myinifile.readsectionvalues('小节名',TStrings变量);可将INI文件中指定小节的所有行(包括关键字、=、值)读取至一个字符串列表变量中去。
这个方法从INI文件中读取一个字符串,Section是指定的键,Ident是指定键下的数据项Default是如果这个项不存在的时候的默认值。
virtual void __fastcallWriteString(const AnsiString Section, const AnsiString Ident, const AnsiString Value);
delete IniFile;
}
以下是TIniFile类常用方法:
DeleteKey
EraseSection
ReadSection
ReadSections
ReadSectionValues
ReadString
TIniFile
UpdateFile
WriteString
ReadBool
ReadDate
ReadDateTime
regKey = new TIniFile ( ExePath + "TrimTxt.ini");
DefaultDir=regKey->ReadString("LastConfig","DefaultDir",ExePath );
delete regKey;
}
下面的例子说明如何将信息写入INI文件
void __fastcall SaveConfig ()
ReadFloat
ReadInteger
ReadTime
SectionExists
WriteBinaryStream
WriteBool
WriteDate
WriteDateTime
WriteFloat
WriteInteger
WriteTime
ValueExists
一、有必要了解INI文件的结构:
;注释
ExtractFileExt 返回完整文件名中的文件扩展名(带.),如".doc"
C++Builder中TIniFile类的使用
在C++Builder中,通过使用TIniFile类可以轻松的对ini文件进行操作。
下面给出一个简单的例子
void __fastcall TMainForm::cbAutoRunClick(TObject *Sender)
myinifile:=Tinifile.Create(filename);
四、读取关键字的值
---针对INI文件支持的字符串、整型数值、布尔值三种数据类型,TINIfiles类提供了三种不同的对象方法来读取INI文件中关键字的值。
---假设已定义变量vs、vi、vb分别为string、integer、boolean类型。
vs:=myinifile.Readstring('小节名','关键字',缺省值);
vi:=myinifile.Readinteger('小节名','关键字',缺省值);
vb:=myinifile.Readbool('小节名','关键字',缺省值);
---其中缺省值为该INI文件不存在该关键字时返回的缺省值。
[小节名]
关键字=值
...
---- INI文件允许有多个小节,每个小节又允许有多个关键字,“=”后面是该关键字的值。
----值的类型有三种:字符串、整型数值和布尔值。其中字符串存贮在INI文件中时没有引号,布尔真值用1表示,布尔假值用0表示。
----注释以分号“;”开头。
二、定义
---- 1、在Interface的Uses节增加IniFiles;
ExtractFileDrive :返回完整文件名中的驱动器,如"C:"
ExtractFilePath:返回完整文件名中的路径,最后带“\”,如C:\test\"
ExtractFileDir:返回完整文件名中的路径,最后不带“\” ,如"C:\test"
ExtractFileName:返回完整文件名中的文件名称 (带扩展名),如"mytest.doc"
---附源程序清单
unit Unit1;
interface
uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,inifiles,StdCtrls, ExtCtrls;
type
TForm1 = class(TForm)
Edit1: TEdit;
CheckBox1: TCheckBox;
Edit2: TEdit;
使用INI配置文件
在BCB中有个TIniFile类,它提供了对INI文件的操作,INI文件一种通用的配置文件格式它也象注册表一样分键和数据项,下面是一个INI配置文件的内容,它有一个键LastConfig,在这个键下有一个数据项DefaultDit,在数据项后面就是这个数据项的值。
[LastConfig]
bool __fastcall SectionExists(const AnsiString Section);
这个方法判断是否存在Section这个键。
virtual AnsiString __fastcallReadString(const AnsiString Section, const AnsiString Ident, const AnsiString Default);
相关主题