Delphi 中 Format 函数的用法详解
Delphi 中 Format 函数的用法详解
Format 是 Delphi 中用于格式化字符串的常用函数,功能类似于 C 语言的 printf 或 C# 的 String.Format。
基本语法
function Format(const FormatStr: string; const Args: array of const): string;
参数说明
- FormatStr:格式字符串,包含普通文本和格式说明符
- Args:可变参数数组,提供要格式化的值
格式说明符语法
格式说明符基本形式:%[index:][-][width][.precision]type
常用格式类型
| 类型 | 说明 | 示例 |
|---|---|---|
| d | 十进制整数 | Format('%d', [10]) → '10' |
| x | 十六进制小写 | Format('%x', [255]) → 'ff' |
| X | 十六进制大写 | Format('%X', [255]) → 'FF' |
| e | 科学计数法 | Format('%e', [1234.567]) → '1.234567E+03' |
| f | 浮点数 | Format('%f', [1234.567]) → '1234.567' |
| g | 通用格式 | Format('%g', [1234.567]) → '1234.567' |
| n | 千位分隔 | Format('%n', [1234.567]) → '1,234.567' |
| m | 货币格式 | Format('%m', [1234.567]) → '¥1,234.57' (取决于区域设置) |
| p | 指针地址 | Format('%p', [@MyVar]) → '0012FEC0' |
| s | 字符串 | Format('%s', ['Delphi']) → 'Delphi' |
使用示例
基本示例
var
s: string;
begin
s := Format('姓名:%s,年龄:%d岁', ['张三', 25]);
// 结果:'姓名:张三,年龄:25岁'
end;
指定参数索引
s := Format('%0:d %1:d %0:d', [10, 20]);
// 结果:'10 20 10'
控制宽度和对齐
s := Format('%-10s%10d', ['测试', 123]);
// 结果:'测试 123'(左对齐和右对齐)
浮点数格式化
s := Format('%.2f', [3.14159]);
// 结果:'3.14'(保留2位小数)
s := Format('%8.2f', [3.14159]);
// 结果:' 3.14'(总宽度8,右对齐)
日期时间格式化
s := Format('日期:%s,时间:%s',
[DateToStr(Now), TimeToStr(Now)]);
多参数复杂格式
s := Format('产品:%s,单价:%m,库存:%d件,占比:%.1f%%',
['手机', 3999.99, 150, 75.5]);
// 结果:'产品:手机,单价:¥3,999.99,库存:150件,占比:75.5%'
注意事项
-
单元引用:
Format函数位于System.SysUtils单元 -
参数匹配:格式说明符数量必须与参数数量匹配
-
性能考虑:频繁调用时,考虑使用
TStringBuilder -
本地化:某些格式(如货币、日期)受系统区域设置影响
-
错误处理:不匹配的格式可能导致异常
高级用法
自定义日期格式
s := FormatDateTime('yyyy-mm-dd hh:nn:ss', Now);
格式化数组
var
arr: array[0..2] of Integer;
begin
arr[0] := 10;
arr[1] := 20;
arr[2] := 30;
s := Format('数组:%d,%d,%d', [arr[0], arr[1], arr[2]]);
end;
Format 是 Delphi 字符串处理中最强大和灵活的函数之一,掌握它可以极大地简化复杂的字符串构建任务。
Delphi 格式说明符详解
格式说明符的基本形式为:%[index:][-][width][.precision]type。下面我将详细解释每个部分的含义:
1. % - 起始符号
- 每个格式说明符都必须以百分号
%开头
2. [index:] - 参数索引(可选)
- 用于指定使用哪个参数(从0开始)
- 格式:数字后跟冒号(如
0:、1:) - 示例:
Format('%1:s %0:s', ['World', 'Hello']) // 结果为 "Hello World"
3. [-] - 对齐方式(可选)
-表示左对齐,默认是右对齐- 示例:
Format('%-10s', ['Hi']) // "Hi " (左对齐,总宽度10) Format('%10s', ['Hi']) // " Hi" (右对齐,总宽度10)
4. [width] - 最小宽度(可选)
- 指定输出内容的最小宽度(字符数)
- 如果实际内容比宽度短,会用空格填充
- 示例:
Format('%5d', [42]) // " 42" (总宽度5)
5. [.precision] - 精度(可选)
- 对于浮点数:指定小数位数
- 对于字符串:指定最大字符数
- 格式:小数点后跟数字
- 示例:
Format('%.2f', [3.14159]) // "3.14" (保留2位小数) Format('%.5s', ['Delphi']) // "Delph" (最多5个字符)
6. type - 格式类型(必需)
- 指定如何格式化参数,必须的最后一个字符
- 常用类型:
d:十进制整数x/X:十六进制(小写/大写)e/E:科学计数法f:固定小数位数g/G:通用格式(自动选择最短表示)n:带千位分隔符的数字m:货币格式p:指针地址s:字符串
综合示例
var
s: string;
begin
// 参数索引:1,左对齐,总宽度15,保留3位小数
s := Format('%1:-15.3f', [3.14159, 123.456789]);
// 结果:"123.457 " (使用第二个参数,左对齐,宽度15)
// 参数索引:0,右对齐,总宽度10,十六进制大写
s := Format('%0:10X', [255]);
// 结果:" FF" (右对齐,宽度10)
// 字符串,最大长度4
s := Format('%.4s', ['Programming']);
// 结果:"Prog"
end;
注意事项
- 方括号
[]表示该部分是可选的,实际使用时不需要写这些括号 - 参数索引从0开始
- 宽度和精度都可以用
*代替,此时从参数中获取值:Format('%*.*f', [8, 2, 3.14159]) // " 3.14" (宽度8,精度2) - 要显示百分号本身,需要使用
%%
浙公网安备 33010602011771号