C++ INI配置文件

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
[小节名]
关键字=值
...
---- INI文件允许有多个小节,每个小节又允许有多个关键字,“=”后面是该关键字的值。
----值的类型有三种:字符串、整型数值和布尔值。其中字符串存贮在INI文件中时没有引号,布尔真值用1表示,布尔假值用0表示。
----注释以分号“;”开头。
二、定义
---- 1、在Interface的Uses节增加IniFiles;
DefaultDir=E:\xxx
TIniFile类有几个常用的方法给大家介绍一下:
__fastcall TIniFile(const AnsiString FileName) : Inifiles::TCustomIniFile(FileName) { }
这个方法创建一个INI对象,如果FileName指定的文件名不存在则自动生成此文件,FileName可以用全路径,指定INI文件的地点,如果只有文件名没有路径,这个函数将到Windows系统路径下去打开或创建。(WIN9X是Windows目录,NT和2000是WINNT目录)
{
TIniFile * regKey;
AnsiString ExePath = ExtractFileName( ParamStr ( 0 ) );
regKey = new TIniFile ( ExePath + "TrimTxt.ini");
regKey->WriteString ( "LastConfig", "DefaultDir" , DefaultDir );
Edit1: TEdit;
CheckBox1: TCheckBox;
Edit2: TEdit;
二、这时创建出来的文件是空的,要往里面写东西,直接调用
ini->WriteInteger("","",);函数
例如ini->WriteInteger("SearchExtTag","CONT",0);这样就在ini文件中生成了,名为SearchExtTag的session,它有一个名为CONT的key,值为0;
--- myinifile.readsections(TStrings变量);可将INI文件中所有小节名读取至一个字符串列表变量中去。
---- myinifile.readsectionvalues('小节名',TStrings变量);可将INI文件中指定小节的所有行(包括关键字、=、值)读取至一个字符串列表变量中去。
使用INI配置文件
在BCB中有个TIniFile类,它提供了对INI文件的操作,INI文件一种通用的配置文件格式它也象注册表一样分键和数据项,下面是一个INI配置文件的内容,它有一个键LastConfig,在这个键下有一个数据项DefaultDit,在数据项后面就是这个数据项的值。
[LastConfig]
这个方法是向INI文件中写入一个字符串,Senction是指定的键,Ident是指定的数据项,Value是要写入的数据。同TRegistry一样,TIniFile类还提供了读取整型、布尔型,二进制等数据类型的读写方法,大家看看联机帮助就可以了,用法基本一样。下面就那上面的INI文件为例来说明一下如何有INI文件来保存配置信息和如何从INI文件中读取数据。
七、小节操作
---增加一个小节可用写入的方法来完成,删除一个小节可用下面的对象方法:
myinifile.EraseSection('小节名');
---另外Tinifile类还提供了三种对象方法来对小节进行操作:
--- myinifile.readsection('小节名',TStrings变量);可将指定小节中的所有关键字名读取至一个字符串列表变量中;
五、写入INI文件
----同样的,TInifile类也提供了三种不同的对象方法,向INI文件写入字符串、整型数及布尔类型的关键字。
myinifile.writestring('小节名','关键字',变量或字符串值);
myinifile.writeinteger('小节名','关键字',变量或整型数值);
delete IniFile;
}
以下是TIniFile类常用方法:
DeleteKey
EraseSection
ReadSection
ReadSections
ReadSectionValues
ReadString
TIniFile
UpdateFile
WriteString
ReadBool
ReadDate
ReadDateTime
在ini文件中表示如下:
[SearchExtTag]
CONT=0;
想添加其他的key可以依次添加
ExtractFilePath()
ExtractFilePath()
功能:返回完整文件名中的路径
函数原型如下:
AnsiString __fastcall ExtractFilePath;
ExtractFilePath和相近函数:
这个方法从INI文件中读取一个字符串,Section是指定的键,Ident是指定键下的数据项Default是如果这个项不存在的时候的默认值。
virtual void __fastcallWriteString(const AnsiString Section, const AnsiString Ident, const AnsiString Value);
或者:
ini = new TIniFile("E:\\BCB\\new\\ReadAndSpeak\\My.ini" );
注意,这里的路径要表示成\\
还可以用ini = new TIniFile( ChangeFileExt( Application->ExeName, ".INI" ) );创建出来的ini文件是以路径最后的文件夹名字取名的
myinifile.writebool('小节名','关键字',变量或True或False);
----当这个INI文件不存在时,上面的语句还会自动创建该INI文件。
六、删除关键字
----除了可用写入方法增加一个关键字,Tinifile类还提供了一个删除关键字的对象方法:
myinifile.DeleteKey('小节名','关键字');
---- 2、在Var变量定义部分增加一行:
myinifile:Tinifile;
----然后,就可以对变量myinifile进行创建、打开、读取、写入等操作了。
三、打开INI文件
myinifile:=Tinifile.create('program.ini');
---上面这一行语句将会为变量myinifile与具体的文件program.ini建立联系,然后,就可以通过变量myinifile,来读写program.ini文件中的关键字的值了。
八、释放
在适当的位置用下面的语句释放myinifile:
myinifile.distory;
九、一个实例
----下面用一个简单的例子(如图),演示了建立、读取、存贮INI文件的方法。myini.ini文件中包含有“程序参数”小节,和用户名称(字符串)、是否正式用户(布尔值)和已运行时间(整型值)三个关键字。程序在窗体建立读取这些数据,并在窗体释放时写myini.ini文件。
ExtractFileDrive :返回完整文件名中的驱动器,如"C:"
ExtractFilePath:返回完整文件名中的路径,最后带“\”,如C:\test\"
ExtractFileDir:返回完整文件名中的路径,最后不带“\” ,如"C:\test"
ExtractFileName:返回完整文件名中的文件名称 (带扩展名),如"mytest.doc"
vs:=myinifile.Readstring('小节名','关键字',缺省值);
vi:=myinifile.Readinteger('小节名','关键字',缺省值);
vb:=myinifile.Readbool('小节名','关键字',缺省值);
---其中缺省值为该INI文件不存在该关键字时返回的缺省值。
ReadFloat
ReadInteger
ReadTime
SectionExisΒιβλιοθήκη Baidus
WriteBinaryStream
WriteBool
WriteDate
WriteDateTime
WriteFloat
WriteInteger
WriteTime
ValueExists
一、有必要了解INI文件的结构:
;注释
{
//读取ini配置文件
TIniFile *IniFile = new TIniFile(ExtractFilePath(Application->ExeName)+"MaskKey.ini");
//向ini文件的Option段中的AutoRun项中写入bool值false
IniFile->WriteBool("Option", "AutoRun", false);
---附源程序清单
unit Unit1;
interface
uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,inifiles,StdCtrls, ExtCtrls;
type
TForm1 = class(TForm)
bool __fastcall SectionExists(const AnsiString Section);
这个方法判断是否存在Section这个键。
virtual AnsiString __fastcallReadString(const AnsiString Section, const AnsiString Ident, const AnsiString Default);
下面的例子是如何从一个INI文件中读取配置,此配置文件保存在应用程序的目录下,如果没有配置,则取程序所在路径为默认值。
#include <inifiles.hpp>
void __fastcall ReadConfig ()
{
//读取配置,
TIniFile * regKey;
AnsiString ExePath = ExtractFileName( ParamStr(0));
delete regKey;
}
使用INI文件保存配置信息是很方便的,它最大的优点就是用户可以手工去就改它,它通常用来保存一些不是至关重要的数据。它的缺点就是不适合保存结构比较复杂的数据,而且文件容易被破坏。
一、例如要在当前路径下建立一个My.ini的文件,代码如下:
TIniFile *ini;
ini =new TIniFile(ExtractFilePath(ParamStr(0))+"My.ini");
regKey = new TIniFile ( ExePath + "TrimTxt.ini");
DefaultDir=regKey->ReadString("LastConfig","DefaultDir",ExePath );
delete regKey;
}
下面的例子说明如何将信息写入INI文件
void __fastcall SaveConfig ()
----值得注意的是,如果括号中的文件名没有指明路径的话,那么这个Program.ini文件会存储在Windows目录中,把Program.ini文件存储在应用程序当前目录中的方法是:为其指定完整的路径及文件名。下面的两条语句可以完成这个功能:
Filename:=ExtractFilePath(Paramstr(0))+'program.ini';
myinifile:=Tinifile.Create(filename);
四、读取关键字的值
---针对INI文件支持的字符串、整型数值、布尔值三种数据类型,TINIfiles类提供了三种不同的对象方法来读取INI文件中关键字的值。
---假设已定义变量vs、vi、vb分别为string、integer、boolean类型。
ExtractFileExt 返回完整文件名中的文件扩展名(带.),如".doc"
C++Builder中TIniFile类的使用
在C++Builder中,通过使用TIniFile类可以轻松的对ini文件进行操作。
下面给出一个简单的例子
void __fastcall TMainForm::cbAutoRunClick(TObject *Sender)
相关文档
最新文档