Difference between revisions of "Using INI Files/zh CN"
Zhouyiran2 (talk | contribs) m (moved Using INI Files/zh to Using INI Files/zh CN) |
Zhouyiran2 (talk | contribs) (→INI 文件) |
||
Line 14: | Line 14: | ||
如今,XML文件经常被用来替代INI文件用作字符串的储存,因为INI文件对较长字符串的支持并不是太好。但是INI(类INI)文件依旧保持着Linux/Unix下设置文件的统治地位 | 如今,XML文件经常被用来替代INI文件用作字符串的储存,因为INI文件对较长字符串的支持并不是太好。但是INI(类INI)文件依旧保持着Linux/Unix下设置文件的统治地位 | ||
− | + | 一个INI文件的简单例子: | |
− | |||
<syntaxhighlight lang="ini"> | <syntaxhighlight lang="ini"> | ||
− | ; | + | ; INI文件开头的注释 |
− | + | ||
− | ; | + | ; 空行将会被忽略 |
− | + | ||
− | ; | + | ; 注意这里并没有定义任何的类目 |
Compiler=Delphi | Compiler=Delphi | ||
− | ; | + | ; 键: Compiler |
− | ; | + | ; 值: Delphi |
− | + | ||
[General] | [General] | ||
− | ; | + | ; 这个标记表示General类目的开始 |
Compiler=FreePascal | Compiler=FreePascal | ||
− | ; | + | ; 键是 Compiler 且值是 FreePascal |
</syntaxhighlight> | </syntaxhighlight> | ||
===Ini 文件读取实例=== | ===Ini 文件读取实例=== | ||
− | + | 下面的命令行程序展示了如何读取INI文件,为了测试这个程序我们必须建立如下的INI文件并保存为“C:\DB.ini”。编辑INI文件使它拥有一个叫做"INIDB"的类目以及如下的键与值: | |
<syntaxhighlight lang="ini"> | <syntaxhighlight lang="ini"> | ||
[INIDB] | [INIDB] | ||
− | ; | + | ; 保存为 C:\DB.ini |
Author=Adam | Author=Adam | ||
Pass= | Pass= | ||
Line 44: | Line 43: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | 现在让我们回到代码 | |
<syntaxhighlight> | <syntaxhighlight> | ||
Program IniSample; | Program IniSample; | ||
{$mode objfpc}{$H+} | {$mode objfpc}{$H+} | ||
− | + | ||
Uses | Uses | ||
Classes,SysUtils,INIFiles; | Classes,SysUtils,INIFiles; | ||
− | + | ||
Var | Var | ||
INI:TINIFile; | INI:TINIFile; | ||
Author,Pass,DBFile:String; | Author,Pass,DBFile:String; | ||
PassEnter:String; | PassEnter:String; | ||
− | + | ||
begin | begin | ||
− | // | + | // 建立INI文件并指定INI文件的位置 |
INI := TINIFile.Create('C:\DB.ini'); | INI := TINIFile.Create('C:\DB.ini'); | ||
− | // | + | // 从INI文件读取字符串的实例 |
− | // | + | // 你也可以读取想Boolean这样别的值 |
Author := INI.ReadString('INIDB','Author',''); | Author := INI.ReadString('INIDB','Author',''); | ||
Pass := INI.ReadString('INIDB','Pass',''); | Pass := INI.ReadString('INIDB','Pass',''); | ||
Line 79: | Line 78: | ||
Writeln('Password : '+Pass); | Writeln('Password : '+Pass); | ||
Readln; | Readln; | ||
− | // | + | // 在使用完INI文件后,你必须调用对象的Free方法 |
− | // ... | + | // 虽然这应该在try...finally块中... |
− | // | + | // 因为这个对象可能因为上述语句的一些错误而过早释放 |
Ini.Free; | Ini.Free; | ||
− | end. | + | end.</syntaxhighlight> |
− | </syntaxhighlight> | ||
− | === | + | ===对象百科=== |
In the TINIFile class there are many different properties, procedures and functions that can be used. | In the TINIFile class there are many different properties, procedures and functions that can be used. | ||
Revision as of 17:31, 21 April 2013
│
العربية (ar) │
Deutsch (de) │
English (en) │
español (es) │
suomi (fi) │
français (fr) │
polski (pl) │
русский (ru) │
中文(中国大陆) (zh_CN) │
INI 文件
基本信息
INI文件可以被方便地用来储存用户基本设置。通过INIfiles单元和TINIFile类,你可以轻松地使用已有的Ini文件。这个单元包括在FCL中。
INI 文件
INI文件使用方括号来创建类目,每个类目中有包含许多键与其值,一个键和与其对应的值使用等于号连接(key=Value)。
类目总是被包含在方括号里 ([Section]).
注释当然是允许的,只要在注释行的开头加上一个分号(;)就可以了。由于INI文件并没有统一的标准,所以其他的一些符号也有可能被使用,比如#。
如今,XML文件经常被用来替代INI文件用作字符串的储存,因为INI文件对较长字符串的支持并不是太好。但是INI(类INI)文件依旧保持着Linux/Unix下设置文件的统治地位
一个INI文件的简单例子:
; INI文件开头的注释
; 空行将会被忽略
; 注意这里并没有定义任何的类目
Compiler=Delphi
; 键: Compiler
; 值: Delphi
[General]
; 这个标记表示General类目的开始
Compiler=FreePascal
; 键是 Compiler 且值是 FreePascal
Ini 文件读取实例
下面的命令行程序展示了如何读取INI文件,为了测试这个程序我们必须建立如下的INI文件并保存为“C:\DB.ini”。编辑INI文件使它拥有一个叫做"INIDB"的类目以及如下的键与值:
[INIDB]
; 保存为 C:\DB.ini
Author=Adam
Pass=
DBFile=C:\Money.dat
现在让我们回到代码
Program IniSample;
{$mode objfpc}{$H+}
Uses
Classes,SysUtils,INIFiles;
Var
INI:TINIFile;
Author,Pass,DBFile:String;
PassEnter:String;
begin
// 建立INI文件并指定INI文件的位置
INI := TINIFile.Create('C:\DB.ini');
// 从INI文件读取字符串的实例
// 你也可以读取想Boolean这样别的值
Author := INI.ReadString('INIDB','Author','');
Pass := INI.ReadString('INIDB','Pass','');
DBFile := INI.ReadString('INIDB','DBFile','');
if Pass <> '' then
begin
Writeln('Password Required');
Repeat
Readln(PassEnter);
if not (PassEnter = Pass) then Writeln('Wrong Password');
until(PassEnter = Pass);
Writeln('Correct Password');
end;
Writeln('Author : '+Author);
Writeln('File : '+DBFile);
Writeln('Password : '+Pass);
Readln;
// 在使用完INI文件后,你必须调用对象的Free方法
// 虽然这应该在try...finally块中...
// 因为这个对象可能因为上述语句的一些错误而过早释放
Ini.Free;
end.
对象百科
In the TINIFile class there are many different properties, procedures and functions that can be used.
CaseSensitive - This property allows you to say if the keys and sections are case sensitive or not. By default they aren't.
ReadString - Has 3 constant statements. The first one is the section to search in. The second one is the key to look for. The third one is a default string in case the key and/or section searched for is not found.
WriteString - has three constant statements, too. The first is the section. The second is the key and the last is the value that you want to write. If the key and section exist already, the key will be overwritten with the new value..
ReadSections - Will allow you to to take the sections from the INI file and put them in a TStrings class (or TStringList with the AS operator).
DeleteKey - Remove an existing key from a specific section.
EraseSection - Remove a section and all its data.
There are more procedures and functions but this is enough to get you started.
Reference Documentation
Here: Free Pascal documentation on INI files