一、数据类型转换函数
  在我们编写程序当中,根据不同情况,会使用到多种数据类型。当要对不同的类型进行操作时,必须要将不同的类型转换成同样的类型。因此熟练地掌握数据类型的转换是非常重要的。

  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);//连接字符串

posted on 2017-08-22 16:26  敲代码的小女孩  阅读(877)  评论(0编辑  收藏  举报