一、数据类型转换函数
在我们编写程序当中,根据不同情况,会使用到多种数据类型。当要对不同的类型进行操作时,必须要将不同的类型转换成同样的类型。因此熟练地掌握数据类型的转换是非常重要的。
1.FloatToStr
功能说明:该函数用于将“浮点型”转换成“字符型”。
参考实例:
Edit1.Text := FloatToStr(1.981);
2.IntToStr
功能说明:该函数用于将“整数型”转换成“字符型”。
参考实例:
S := IntToStr(10);(注:S为String类型变量。)
3.IntToHex
功能说明:该函数用于将“十进制”转换成“十进制”。该函数有二个参数。第一个参数为要转换的十进制数据,第二个参数是指定使用多少位来显示十六进制数据。
参考实例:
Edit1.Text := IntToHex('100', 2);
执行结果,Edit1.Text等于64。
注意:Delphi没有提供专门的“十六进制”转换为“十进制”的函数。使用StrToInt函数可以实现这个功能。具体代码是:I := StrToInt('S/' + '64'); 这时I等于100。加上一个'S/'即可将“十六进制”转换为“十进制”。
4.StrToInt
功能说明:该函数用于将“字符型”转换成“整数型”。
参考实例:
I := StrToInt('100');
注意:不能转换如 StrToInt('ab')或StrToInt('好')这样的类型,因为他们并不存在数字型。
5.StrToFloat
功能说明:该函数用于将“字符型”转换成“浮点型”。
参考实例:
N := StrToFloat(Edit1.Text);
注意:Edit1.Text中的内容为1.981(凡在Edit控件中显示的文本均为字符串)。N为Double类型,用于保存转换后的浮点型数据。
二、字符串、数组操作函数
对字符串及数组的操作,是每个程序员必须要掌握的。熟练的使用这些函数,在编程时能更加得心应手。
1.Copy
功能说明:该函数用于从字符串中复制指定范围中的字符。该函数有3个参数。第一个参数是数据源(即被复制的字符串),第二个参数是从字符串某一处开始复制,第三个参数是要复制字符串的长度(即个数)。最后函数返回一个新的字符串(即是我们指定要复制的字符串内容)。
参考实例:
var
S: String;
MyStr: String; // 保存新的字符串
begin
S := 'I Love China!';
//下面将获取I Love China中的“Love”字符串。
MyStr := Copy(S, 3, 4);
end;
执行结果,MyStr等于“Love”,“Love”字符串在“I Love China!”中第3个位置开始,所以第二个参数为3,“Love”一共有4个字符,所以第三个参数为4。
2.Concat
功能说明:连接两个或多个字符串为一个字符串。
参考实例:
var
S1, S2: String;
begin
S1 := Concat('A', 'B'); // 连接两个字符串,S1变量等于AB。
S2 := Concat('Borland', ' Delphi', ' 7.0'); // 连接三个字符,S2变量等于Borland Delphi 7.0。
end;
3.Delete
功能说明:删除字符串中指定的字符串。该函数有三个参数。第一个参数为要进行处理的字符串,第二个参数为从何处开始删除,第三个参数为删除的字符个数。
参考实例:
var
S: String;
begin
S := 'I Like Reading CPCW.';
// 下面的代码将删除S变量中的“C”字符。
Delete(S, 16, 1);
end;
此时S变量则是I Like Reading PCW.(“C”已经不存在了)。
4.High
功能说明:返回数组下标的最大值。
参考实例:
var
arrText: array[0..9] of Char;
i: Integer;
begin
i := High(arrText); // i的值则为9
end;
5.Insert
功能说明:插入一个字符(串)。该函数有三个参数。第一个参数为要插入的字符(串),第二个参数为被插入字符串(源字符串),第三个参数为从何处插入。
参考实例:
var
S: String;
begin
S := 'Wat is your name?';
// 上面句子中的What单词查一个“h”字符,下面使用Insert函数将h添加进去。
Insert('h', S, 2); // 将“h”从第2位处插入。
end;
6.LeftStr(所在单元:StrUtils)
功能说明:返回字符串左边指定个数的新字符(串)。该函数有两个参数。第一个参数为完整的字符串,第二个参数为指定个数。
参考实例:
var
S, A: String;
begin
S := 'MSN Messenger';
A := LeftStr(S, 3); // 从最左边开始,获取左边的三个字符。因此A变量则等于MSN。
end;
7.Length
功能说明:该函数用于统计指定字符串的长度(即个数)。
参考实例:
var
nLen1, nLen2: Integer; // 用于保存字符串长度
begin
nLen1 := Length('CPCW');
nLen2 := Length('电脑报');
end;
执行结果,nLen1等于4,nLen2等于6。由于一个汉字相当于两个字符的长度,所以3个汉字的长度为6。
8.Low
功能说明:返回数组下标的最小值。
参考实例:
var
arrText: array[1..9] of Char;
i: Integer;
begin
i:= High(arrText); // i的值则为1
end;
9.LowerCase
功能说明:将字符(串)中的英文字符转换为小写。
参考实例:
var
S, A: String;
begin
S := 'ABC';
A := UpperCase(S); // 经过UpperCase函数转换后,A则等于abc。
end;
10.MidStr(所在单元:StrUtils)
功能说明:返回指定范围内的字符串。该函数有三个参数。第一个参数为源字符串,第二个参数为起点,第三个参数为结束点。通过第二、第三个参数则可指定要复制字符串的范围。
Copy函数与此函数类似。MidStr主要用于处理含有中文字符的字符串。
参考实例:
var
S: String;
H: String;
begin
S := MidStr('China', 1, 2); // S变量为Ch
H := MidStr('电脑报', 1, 1); // H变量为“电”。如果使用Copy函数,则应是H := Copy('电脑报, 1, 2),否则返回的将不是“电”字。因此在使用操作含有中文的字符串时,最好使用MidStr。
end;
11.Pos
功能说明:查找字符(串)所在位置。该函数有二个参数。第一个参数为要查找的字符(串),第二个参数为被查找字符(串)。
参考实例:
var
nPos: Integer; // 用于保存查找的字符所在位置
begin
nPos := Pos('Like', 'I Like Reading!');
end;
此时nPos等于3。如果没有查找到,则nPos为0。
注意:Pos函数在查找时是要区分字符大小的。如果要实现不区分大小,那么需要使用UpperCase或LowerCase函数将两个参数的字符(串)转换为“大写”或“小写”再进行查找。
另外还有一个查找字符(串)的函数----AnsiPos,该函数的使用方法与Pos函数完全一样。当你查找的是汉字时,最好使用AnsiPos函数。
12.RightStr(所在单元:StrUtils)
功能说明:返回字符串右边指定个数的新字符(串)。该函数有两个参数。第一个参数为完整的字符串,第二个参数为指定个数。
参考实例:
var
S, A: String;
begin
S := 'MSN Messenger';
A := RightStr(S, 3); // 从最右边开始,获取右边的三个字符。因此A变量则等于ger。
end;
13.SetLength
功能说明:设置字符串或动态数组长度。该函数有两个参数。第一个参数为要设置的字符串变量或动态数组变量,第二个参数为指定的长度,其取值范围在0到255之间。
参考实例:
var
S: String;
arrText: array of Char; // 定义一个动态数组
begin
SetLength(S, 10); // 当设置后,S变量只能赋值长度为10的字符串。
SetLength(arrText, 10); // 只有使用SetLength为动态数组分配内存空间后才能使用动态数组。这句代码的作用相当于arrText: array[0..9] of Char
end;
14.StrPCopy
功能说明:将字符串复制到字符数组中。该函数有两个参数。第一个参数为“目标数组”,第二个参数为“字符串”。
参考实例:
var
arrChar: array[0..255] of Char; // 这里声明了长度为256的Char型数组
begin
StrPCopy(arrChar, 'Come on, baby!');
end;
15.Trim
功能说明:删除字符串左右两边的空格(无论左右两边有多少个空格均被全部删除)。
参考实例:
var
S: String;
begin
S := ' Delphi 7.0 ';
S := Trim(S);
end;
16.TrimLeft
功能说明:删除字符串左边的空格(无论左边有多少个空格均被全部删除)。
参考实例:
S := TrimLeft(' Delphi');
17.TrimRight
功能说明:删除字符串左边的空格(无论左边有多少个空格均被全部删除)。
参考实例:
S := TrimRight('Delphi ');
18.UpperCase
功能说明:将字符(串)中的英文字符转换为大写。
参考实例:
var
S, A: String;
begin
S := 'abc';
A := UpperCase(S); // 经过UpperCase函数转换后,A则等于ABC。
end;
三、文件、磁盘操作函数
软件大多都要对文件、磁盘进行操作。熟悉掌握这些函数可以帮助你轻松实现创建、删除、保存文件等功能。
1.Append
功能说明:追加内容到文件中。文件必须要存在。
参考实例:
var
S: String;
F: TextFile;
begin
S := 'This is a book.';
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Append(F); // 以追加的方式打开文件
Writeln(F, S); // 将S变量中的内容追加到文本尾后。
CloseFile(F); // 关闭文件
end;
2.AssignFile
功能说明:与指定的文件建立连接。
参考实例:
var
F: TextFile; // 声明文本文件类型变量
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
end;
3.ChDir
功能说明:改变当前目录(文件夹)。
参考实例:
var
sDir: String;
begin
sDir := 'C:/Windows';
ChDir(sDir); // 此时,系统的当前目录则为C:/Windows目录。
end;
4.CloseFile
功能说明:关闭文件。当对文件的操作完成后,应该使用CloseFile函数关闭打开的文件。
参考实例:
var
S: String;
AllText: String;
F: TextFile;
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Reset(F); // 打开文件
while not EOF(F) do begin // 使用While循环,一直判断是否到了文件未尾
Readln(F, S); // 读取一行文本
AllText := AllText + S;
end;
CloseFile(F); // 关闭文件
end;
5.DeleteFile
功能说明:删除指定的文件。该函数只有一个参数。此参数为欲删除文件的完整路径。如果删除成功,则返回True。若删除失败、或文件不存在则返回False。
参考实例:
var
IsOK: Boolean; // 用于保存删除状态
begin
IsOK := DeleteFile('C:/My Documents/Index.html'); // 函数执着后,将结果返回给IsOK变量。如果IsOK变量为True,则表示文件删除成功。
if IsOK then ShowMessage('文件删除成功!')
else ShowMessage('文件删除失败!');
end;
6.DirectoryExists
功能说明:检测指定的文件夹否存在。如果存在则返回True,反之则为False。
参考实例:
var
IsExists: Boolean;
begin
IsExists := DirectoryExists ('C:/Windows');
if IsExists then ShowMessage('Windows文件夹存在!')
else ShowMessage('Windows文件夹不存在!');
end;
7.DiskFree
功能说明:获取指定磁盘的剩余空间。该函数只有一个参数。该参数用于指定要获取剩余空间的磁盘号。当参数为0时,表示获取当前磁盘的剩余空间,1为A盘,2为B盘,以此类推。如果返回值为-1,表示指定的磁盘无效。
参考实例:
var
FreeSize: Int64;
begin
FreeSize := DiskFree(3); // 获取C盘中的剩余空间。返回的值是以“字节”为单位的。
end;
8.DiskSize
功能说明:获取指定磁盘的空间。该函数只有一个参数。该参数用于指定要获取磁盘空间的磁盘号。当参数为0时,表示获取当前磁盘的空间,1为A盘,2为B盘,以此类推。如果返回值为-1,表示指定的磁盘无效。
参考实例:
var
DiskSize: Int64;
begin
DiskSize:= DiskSize(3); // 获取C盘的空间。返回的值是以“字节”为单位的。
end;
9.EOF
功能说明:判断文件指针是否移动到了文件未尾。当EOF函数返回值为True时,则不可以使用Readln函数进行读取文件了。
参考实例:
var
S: String;
AllText: String;
F: TextFile;
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Reset(F); // 打开文件
while not EOF(F) do begin // 使用While循环,一直判断是否到了文件未尾
Readln(F, S); // 读取一行文本
AllText := AllText + S;
end;
end;
10.Erase
功能说明:删除文件。
参考实例:
var
F: File;
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Reset(F); // 打开文件
CloseFile(F); // 关闭文件
Erase(F); // 删除文件。在删除文件之前必须先关闭文件。
end;
11.FileExists
功能说明:检测指定的文件否存在。如果存在则返回True,反之则为False。
参考实例:
var
IsExists: Boolean;
begin
IsExists := FileExists('C:/Test.txt');
if IsExists then ShowMessage('该文件存在!')
else ShowMessage('该文件不存在!');
end;
12.FileSize
功能说明:获取文件大小。返回的结果是字节为单位。
参考实例:
var
F: file of Byte;
nSize: Longint;
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Reset(F); // 打开文件
nSize := FileSize(F); // 获取文件大小。
CloseFile(F); // 关闭文件
end;
13.ForceDirectories
功能说明:创建新的子目录。路径中不存在的目录将一同创建。
参考实例:
ForceDirectories('C:/Flash/MyFolder'); // 如果Flash文件夹本身不存的话,那么将会先创建Flash文件夹,然后再创建MyFolder文件夹。
14.MkDir
功能说明:创建一个新的子目录(文件夹)。
参考实例:
MkDir('C:/MyFolder'); // 在C盘根目录中创建了一个名叫MyFolder的文件夹。
需要注意的是,如果在本身不存在的目录中创建子目录将会失败。比如C盘根本不存在Flash文件夹,写成MkDir('C:/Flash/MyFolder');这样将不能成功创建MyFolder文件夹。
15.Reset
功能说明:以只读方式打开文件。
参考实例:
var
F: TextFile; // 声明文本文件类型变量
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Reset(F); // 打开文件
end;
16.Rewrite
功能说明:以可写方式打开文件。如果文件不存在,将会自动创建。使用该函数,将会覆盖文件中的所有内容。
参考实例:
var
F: TextFile; // 声明文本文件类型变量
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Rewrite(F); // 打开文件。如果文件不存在,将会在C盘中创建MyFile.txt文件。如果文件存在,将会覆盖MyFile.txt中的所有内容。
end;
17.Readln
功能说明:读取一行文本。
参考实例:
var
S: String;
F: TextFile;
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Reset(F); // 打开文件
Readln(F, S); // 读取一行文本到S变量中
end;
18.Rename
功能说明:更改文件名。
参考实例:
var
F: File;
begin
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
ReName(F, 'C:/NewFile.txt'); // 更名为NewFile.txt
end;
19.Writeln
功能说明:写入一行文本。
参考实例:
var
S: String;
F: TextFile;
begin
S := 'This is a book.';
AssignFile(F, 'C:/MyFile.txt'); // 将C:/MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。
Rewrite(F); // 创建新文件
Writeln(F, S); // 将S变量中的内容写入文本中。
end;
四、内存、指针操作函数
在编程中,动态数组为我们处理数据带来了很大的方便。Windows API函数也为增强程序的功能提供了强有力的保障。当我们在使用这些动态数组及API函数时,常常需要动态分配内存空间,这样动态数组才能被我们使用,API函数才能正确的返回结果。因此,这些函数是必不可少的。
1.AllocMem
功能说明:分配内存空间并自动初始化为零。如果不需要初始化为零,可以使用GetMem代替AllocMem。
参考实例:
var
Buffer: PChar;
begin
Buffer := AllocMem(256); // 分配大小为256个字节的内存空间
end;
2.Dispose
功能说明:释放为指针分配的内存空间。
参考实例:
var
P: Pinteger; // 声明一个Integer(整型)指针
begin
New(P);
P^ := 100;
Dispose(P) // 释放内存
end;
3.FreeMem
功能说明:释放分配的内存空间。
参考实例:
var
Buffer: Pchar;
begin
GetMem(Buffer, 256); // 分配大小为256个字节的内存空间。
FreeMem(Buffer); // 释放内存空间
end;
4.GetMem
功能说明:分配内存空间。
参考实例:
var
Buffer: PChar;
begin
GetMem(Buffer, 256); // 分配大小为256个字节的内存空间。
end;
5.New
功能说明:为指针分配内存空间。
参考实例:
var
P: PInteger; // 声明一个Integer(整型)指针
begin
New(P); // 分配内存
P^ := 100; // 赋值
end;
五、数学运算函数
我们在编写跟数学紧密相关的程序时,数学运算函数将大有用处。比如图像处理软件,就会大量用到这些数学运算函数。
默认情况下,Delphi新建的工程里,没有包含大多数的数学运行函数,因此需要在Uses中加入Math单元。
1.Abs
功能说明:求绝对值。
参考实例:
var
r: Single;
i: Integer;
begin
r := Abs(-2.8); // r等于 2.8
i := Abs(-156); // I 等于 156
end;
2.Exp
功能说明:Exp返回e的X次幂的值,其中e是一个自然对数基底。
参考实例:
e := Exp(1.0); // e为real型变量
end;
3.Floor
功能说明:取得小于等于X的最大的整数。
参考实例:
Floor(-2.8) = -3
Floor(2.8) = 2
Floor(-1.0) = -1
4.Int
功能说明:返回参数中的整数部分。
参考实例:
var
R: Real;
begin
R := Int(123.456); // R等于 123.0
R := Int(-123.456); // R等于 -123.0
end;
5.Max(所在单元:Math)
功能说明:比较两个数字,并返回最大的一个数字。
参考实例:
var
k: Integer;
begin
k := Max(10, 20); // k将为20
end;
6.Min(所在单元:Math)
功能说明:比较两个数字,并返回最小的一个数字。
参考实例:
var
k: Integer;
begin
k := Min(10, 20); // k将为10
end;
7.PI
功能说明:精确计算返回圆周率。
参考实例:
var
x Extended;
begin
x := PI; // x等于3.1415926535897932385
end;
8.Round
功能说明:对一个实数进行四舍五入。
参考实例:
var
I, j: Integer;
begin
i := Round(1.25); // i等于1
j := Round(1.62); // j等于2
end;
9.Sqr
功能说明:取给定值的平方。
参考实例:
var
i: Integer;
begin
i := Sqr(3); // i等于9
end;
六、日期函数
对日期的处理,一般在有日期限制的共享、商业软件中经常使用到。如果你打算编写一款有日期限制的软件,熟悉使用下面的函数即可以实现。
1.Date
功能说明:返回当前的日期。
参考实例:
procedure TForm1.Button1Click(Sender: TObject);
begin
Label1.Caption := '今天是:' + DateToStr(Date);
end;
Label显示为:今天是2005年1月1日。
2.DateToStr
功能说明:将日期型转换为字符型。
参考实例:
var
S: String;
begin
S := DateToStr(Date);
end;
3.DateTimeToStr
功能说明:将DateTime型转换为字符型。
参考实例:
var
S: String;
begin
S := DateTimeToStr(Now);
end;
4.DayOfTheMonth(所在单元:DateUtils)
功能说明:获取指定日期的日。
参考实例:
Label1.Caption := IntToStr(DayOfTheMonth(Now));
假设当前日期为2005年1月2日,那么Label将显示为2。
5.DayOfTheWeek(所在单元:DateUtils)
功能说明:根据指定日期,获取星期几。
参考实例:
Label1.Caption := IntToStr(DayOfTheMonth(Now));
假设当前日期为2005年1月2日,那么Label将显示为7。根据返回的值来判断是周几。7表示星期天,1为星期一,依类类推。
6.DayOfTheYear(所在单元:DateUtils)
功能说明:根据指定日期,获取天数。
参考实例:
Label1.Caption := IntToStr(DayOfTheYear(Now));
假设当前日期为2005年1月2日,那么Label将显示为2。表示是2005年的第2天。
7.DayOf(所在单元:DateUtils)
功能说明:根据指定的日期,返回日。
参考实例:
Label1.Caption := IntToStr(DayOf(Date));
假设当前日期为2005年1月2日,那么Label将显示为2。
8.IsLeapYear
功能说明:根据指定的年,判断是否为闰年。可使用YearOf函数获取年。
参考实例:
procedure TForm1.Button1Click(Sender: TObject);
begin
if IsLeapYear(YearOf(Date)) then ShowMessage('是闰年')
else ShowMessage('不是闰年');
end;
9.MonthOf(所在单元:DateUtils)
功能说明:根据指定的日期,返回月份。
参考实例:
Label1.Caption := IntToStr(MonthOf(Date));
假设当前日期为2005年1月2日,那么Label将显示为1。
10.Now
功能说明:返回当前日期及时间。
参考实例:
procedure TForm1.Button1Click(Sender: TObject);
begin
Label1.Caption := '现在是:' + DateTimeToStr(Now);
end;
11.YearOf(所在单元:DateUtils)
功能说明:根据指定的日期,返回年。
参考实例:
Label1.Caption := IntToStr(YearOf(Date));
假设当前日期为2005年1月2日,那么Label将显示为2005。
KeyLife富翁笔记
作者�: aricyoung
标题�: delphi中的Format函数详解
关键字:
分类�: 常用函数
密级�: 保护
(评分: , 回复: 0, 阅读: 17) »»
Format是一个很常用,却又似乎很烦的方法,本人试图对这个方法的帮助进行一些翻译,让它有一个完整的概貌,以供大家查询之用:
首先看它的声明:
function Format(const Format: string; const Args: array of const): string; overload;
事实上Format方法有两个种形式,另外一种是三个参数的,主要区别在于它是线程安全的,
但并不多用,所以这里只对第一个介绍:
function Format(const Format: string; const Args: array of const): string; overload;
Format参数是一个格式字符串,用于格式化Args里面的值的。Args又是什么呢,
它是一个变体数组,即它里面可以有多个参数,而且每个参数可以不同。
如以下例子:
Format('my name is %6s',['wind']);
返回后就是my name is wind
现在来看Format参数的详细情况:
Format里面可以写普通的字符串,比如'my name is',但有些格式指令字符具有特殊意义,比如"%6s"格式指令具有以下的形式:
"%" [index ":"] ["-"] [width] ["." prec] type
它是以"%"开始,而以type结束,type表示一个具体的类型。中间是用来
格式化type类型的指令字符,是可选的。
先来看看type,type可以是以下字符:
d 十制数,表示一个整型值
u 和d一样是整型值,但它是无符号的,而如果它对应的值是负的,则返回时是一个2的32次方减去这个绝对值的数,如:
Format('this is %u',[-2]);
返回的是:this is 4294967294
f 对应浮点数
e 科学表示法,对应整型数和浮点数,比如
Format('this is %e',[-2.22]);
返回的是:this is -2.22000000000000E+000,等一下再说明如果将数的精度缩小
g 这个只能对应浮点型,且它会将值中多余的数去掉,比如
Format('this is %g',[02.200]);
返回的是:this is 2.2
n 只能对应浮点型,将值转化为号码的形式。看一个例子就明白了
Format('this is %n',[4552.2176]);
返回的是this is 4,552.22
注意有两点,一是只表示到小数后两位,等一下说怎么消除这种情况, 二是,即使小数没有被截断,它也不会也像整数部分一样有逗号来分开的
m钱币类型,但关于货币类型有更好的格式化方法,这里只是简单的格式化,另外它只对应于浮点值
Format('this is %m',[9552.21]);
返回:this is ¥9,552.21
p 对应于指针类型,返回的值是指针的地址,以十六进制的形式来表示
例如:
var X:integer;
p:^integer;
begin
X:=99;
p:=@X;
Edit1.Text:=Format('this is %p',[p]);
end;
Edit1的内容是:this is 0012F548
s 对应字符串类型,不用多说了吧
x 必须是一个整形值,以十六进制的形式返回
Edit1.Text:=Format('this is %X',[15]);
返回是:this is F
类型讲述完毕,下面介绍格式化Type的指令:
[index ":"]这个要怎么表达呢,看一个例子
Format('this is %d %d',[12,13]);
其中第一个%d的索引是0,第二个%d是1,所以字符显示的时候是这样 this is 12 13
而如果你这样定义:
Format('this is %1:d %0:d',[12,13]);
那么返回的字符串就变成了this is 13 12。现在明白了吗,[index ":"] 中的index指示Args中参数显示的顺序还有一种情况,如果这样
Format('%d %d %d %0:d %d', [1, 2, 3, 4])
将返回1 2 3 1 2。
如果你想返回的是1 2 3 1 4,必须这样定:
Format('%d %d %d %0:d %3:d', [1, 2, 3, 4])
但用的时候要注意,索引不能超出Args中的个数,不然会引起异常如
Format('this is %2:d %0:d',[12,13]);
由于Args中只有12 13 两个数,所以Index只能是0或1,这里为2就错了[width] 指定将被格式化的值占的宽度,看一个例子就明白了
Format('this is %4d',[12]);
输出是:this is 12,这个是比较容易,不过如果Width的值小于参数的长度,则没有效果。
如:
Format('this is %1d',[12]);
输出是:this is 12
["-"]这个指定参数向左齐,和[width]合在一起最可以看到效果:
Format('this is %-4d,yes',[12]);
输出是:this is 12 ,yes
["." prec] 指定精度,对于浮点数效果最佳:
Format('this is %.2f',['1.1234]);
输出 this is 1.12
Format('this is %.7f',['1.1234]);
输出了 this is 1.1234000
而对于整型数,如果prec比如整型的位数小,则没有效果反之比整形值的位数大,则会在整型值的前面以0补之
Format('this is %.7d',[1234]);
输出是:this is 0001234]
对于字符型,刚好和整型值相反,如果prec比字符串型的长度大则没有效果,反之比字符串型的长度小,则会截断尾部的字符
Format('this is %.2s',['1234']);
输出是 this is 12,而上面说的这个例子:
Format('this is %e',[-2.22]);
返回的是:this is -2.22000000000000E+000,怎么去掉多余的0呢,这个就行啦
Format('this is %.2e',[-2.22]);
好了,第一个总算讲完了,应该对他的应用很熟悉了吧
///////////////////////////////////////////////////////////////
二 FormatDateTime的用法
他的声明为:
function FormatDateTime(const Format: string; DateTime: TDateTime): string;
overload;
当然和Format一样还有一种,但这里只介绍常用的第一种,Format参数是一个格式化字符串。DateTime是时间类型。返回值是一种格式化后的字符串,重点来看Format参数中的指令字符
c 以短时间格式显示时间,即全部是数字的表示
FormatdateTime('c',now);
输出为:2004-8-7 9:55:40
d 对应于时间中的日期,日期是一位则显示一位,两位则显示两位
FormatdateTime('d',now);
输出可能为1~31
dd 和d的意义一样,但它始终是以两位来显示的
FormatdateTime('dd',now);
输出可能为01~31
ddd 显示的是星期几
FormatdateTime('ddd',now);
输出为: 星期六
dddd 和ddd显示的是一样的。 但上面两个如果在其他国家可能不一样。ddddd 以短时间格式显示年月日
FormatdateTime('ddddd',now);
输出为:2004-8-7
dddddd 以长时间格式显示年月日
FormatdateTime('dddddd',now);
输出为:2004年8月7日
e/ee/eee/eeee 以相应的位数显示年
FormatdateTime('ee',now);
输出为:04 (表示04年)
m/mm/mmm/mmmm 表示月
FormatdateTime('m',now);
输出为:8
FormatdateTime('mm',now);
输出为 08
FormatdateTime('mmm',now);
输出为 八月
FormatdateTime('mmmm',now);
输出为 八月
和ddd/dddd 一样,在其他国家可能不同yy/yyyy 表示年
FormatdateTime('yy',now);
输出为 04
FormatdateTime('yyyy',now);
输出为 2004,
h/hh,n/nn,s/ss,z/zzz 分别表示小时,分,秒,毫秒
t 以短时间格式显示时间
FormatdateTime('t',now);
输出为 10:17
tt 以长时间格式显示时间
FormatdateTime('tt',now);
输出为10:18:46
ampm 以长时间格式显示上午还是下午
FormatdateTime('ttampm',now);
输出为:10:22:57上午
大概如此,如果要在Format中加普通的字符串,可以用双引号隔开那些特定义的字符,这样普通字符串中如果含特殊的字符就不会被显示为时间格式啦:
FormatdateTime('"today is" c',now);
输出为:today is 2004-8-7 10:26:58
时间中也可以加"-"或"/"来分开日期:
FormatdateTime('"today is" yy-mm-dd',now);
FormatdateTime('"today is" yy/mm/dd',now);
输出为: today is 04-08-07
也可以用":"来分开时间
FormatdateTime('"today is" hh:nn:ss',now);
输出为:today is 10:32:23
/////////////////////////////////////////////////////////////////
三.FormatFloat的用法
常用的声明:
function FormatFloat(const Format: string; Value: Extended): string; overload;
和上面一样Format参数为格式化指令字符,Value为Extended类型为什么是这个类型,因为它是所有浮点值中表示范围最大的,如果传入该方法的参数比如Double或者其他,则可以保存不会超出范围。
关键是看Format参数的用法
0 这个指定相应的位数的指令。
比如:
FormatFloat('000.000',22.22);
输出的就是022.220
注意一点,如果整数部分的0的个数小于Value参数中整数的位数,则没有效果如:
FormatFloat('0.00',22.22);
输出的是:22.22
但如果小数部分的0小于Value中小数的倍数,则会截去相应的小数和位数如:
FormatFloat('0.0',22.22);
输出的是:22.2
也可以在整数0中指定逗号,这个整数位数必须大于3个,才会有逗号出句
FormatFloat('0,000.0',2222.22);
输出是:2,222.2
如果这样
FormatFloat('000,0.0',2222.22);
它的输出还是:2,222.2
注意它的规律,#和0的用法一样,目前我还没有测出有什么不同。
FormatFloat('##.##',22.22);
输出是:22.00
E 科学表示法,看几个例子大概就明白了
FormatFloat('0.00E+00',2222.22);
输出是 2.22E+03
FormatFloat('0000.00E+00',2222.22);
输出是 2222.22E+00
FormatFloat('00.0E+0',2222.22);
22.2E+2
明白了吗,全靠E右边的0来支配的。
这个方法并不难,大概就是这样子了。
上面三个方法是很常用的,没有什么技巧,只要记得这些规范就行了。
总结一下Format的用法:
Format('x=%d',[12]);//'x=12'//最普通
Format('x=%3d',[12]);//'x=12'//指定宽度
Format('x=%f',[12.0]);//'x=12.00'//浮点数
Format('x=%.3f',[12.0]);//'x=12.000'//指定小数
Format('x=%8.2f'[12.0])//'x=12.00';
Format('x=%.*f',[5,12.0]);//'x=12.00000'//动态配置
Format('x=%.5d',[12]);//'x=00012'//前面补充0
Format('x=%.5x',[12]);//'x=0000C'//十六进制
Format('x=%1:d%0:d',[12,13]);//'x=1312'//使用索引
Format('x=%p',[nil]);//'x=00000000'//指针
Format('x=%1.1e',[12.0]);//'x=1.2E+001'//科学记数法
Format('x=%%',[]);//'x=%'//得到"%"
S:=Format('%s%d',[S,I]);//S:=S+StrToInt(I);//连接字符串