• Delphi 数据、文件常用函数


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

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

  • 相关阅读:
    第一次接触 cef, 遇到不少的问题
    数据结构:并查集
    fel基本使用
    fel兼容多值计算
    CEF3开发者系列之单进程模式应用
    MybatisPlus查询整理
    统一异常/服务处理
    京东工作阶段....
    js 前端使用 prettier格式化scss
    vu3 动态组件
  • 原文地址:https://www.cnblogs.com/Little-Star/p/7412225.html
Copyright © 2020-2023  润新知