function Format(const Format: string; const Args: array of const): string;

function Format(const Format: string; const Args: array of const;const FormatSettings: TFormatSettings): string;

Format参数是一个格式字符串,用于格式化Args里面的值的Args是一个变体数组,即它里面可以有多个参数,而且每个参数可以不同。
如以下例子:

Format('my name is %6s',['wind']);  //返回  my name is wind

Format里面可以写普通的字符串,比如'my name is',但有些格式指令字符具有特殊意义,比如"%6s"格式指令具有以下的形式:"%" [index ":"] ["-"] [width] ["." prec] type
它是以"%"开始,而以type结束,type表示一个具体的类型。中间是用来格式化type类型的指令字符,可选。

1、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 对应于指针类型,返回的值是指针的地址,以十六进制的形式来表示
  例如:

  1. var
  2. X:integer;
  3. p:^integer;
  4. begin
  5. X:=99;
  6. p:=@X;
  7. Edit1.Text:=Format('this is %p',[p]); //Edit1返回内容:this is 0012F548
  8. end;

  s 对应字符串类型
  x 必须是一个整形值,以十六进制的形式返回,例如:
  Edit1.Text:=Format('this is %X',[15]);  //返回:this is F

2、格式化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
  Format('%d %d %d %0:d %d', [1, 2, 3, 4])       //返回1 2 3 1 2。

Format('%d %d %d %0:d %3:d', [1, 2, 3, 4])     //返回的是1 2 3 1 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

3、["-"]  指定参数向左齐,和[width]合在一起最可以看到效果:
  Format('this is %-4d,yes',[12]);   //输出是:this is 12 ,yes

4、["." 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,

Format('this is %.2e',[-2.22]);  //去掉多余的0

来源:https://www.cnblogs.com/guorongtao/p/11970803.html

 修改于:2019.12.02

Delphi 格式化函数 Format函数的更多相关文章

  1. Python 的格式化字符串format函数

    阅读mattkang在csdn中的博客<飘逸的python - 增强的格式化字符串format函数>所做笔记 自从python2.6开始,新增了一种格式化字符串的函数str.format( ...

  2. 飘逸的python - 增强的格式化字符串format函数

    自python2.6开始,新增了一种格式化字符串的函数str.format(),可谓威力十足.那么,他跟之前的%型格式化字符串相比,有什么优越的存在呢?让我们来揭开它羞答答的面纱. 语法 它通过{}和 ...

  3. 格式化字符串format函数

    自python2.6开始,新增了一种格式化字符串的函数str.format(),可谓威力十足.那么,他跟之前的%型格式化字符串相比,有什么优越的存在呢?让我们来揭开它羞答答的面纱. 语法 它通过{}和 ...

  4. (转)飘逸的python - 增强的格式化字符串format函数

    原文:https://blog.csdn.net/handsomekang/article/details/9183303 Python字符串格式化--format()方法-----https://b ...

  5. 增强的格式化字符串format函数

    http://blog.csdn.net/handsomekang/article/details/9183303 自python2.6开始,新增了一种格式化字符串的函数str.format(),可谓 ...

  6. 【Python开发】增强的格式化字符串format函数

    自python2.6开始,新增了一种格式化字符串的函数str.format(),可谓威力十足.那么,他跟之前的%型格式化字符串相比,有什么优越的存在呢?让我们来揭开它羞答答的面纱. 语法 它通过{}和 ...

  7. python - 增强的格式化字符串format函数

    语法 它通过{}和:来代替%. “映射”示例 通过位置 In [1]: '{0},{1}'.format('kzc',18) Out[1]: 'kzc,18' In [2]: '{},{}'.form ...

  8. python字符串格式化方法 format函数的使用

      python从2.6开始支持format,新的更加容易读懂的字符串格式化方法, 从原来的% 模式变成新的可读性更强的 花括号声明{}.用于渲染前的参数引用声明, 花括号里可以用数字代表引用参数的序 ...

  9. python格式化字符串format函数

    1. format可以接受无限个的参数,位置可以不按顺序: In [1]: "{} {}".format("hello","world") ...

随机推荐

  1. keras及神经网络,以简单实例入门

    由浅入深,深入浅出.还给你reference了很多,如果你想要更多. 迄今为止看到最棒的,最值得follow的入门tutorial: https://realpython.com/python-ker ...

  2. oracle集合的应用

    union:求并集,公共部分只包含一个 ABC 和AB都没有显示出来 2:union all 相同的数据会包含两个 3:交集 intersect 既包含A又包含B 4:求差集  A集合中的数据B集合中 ...

  3. PHP curl_errno函数

    curl_errno — 返回最后一次的错误号 说明 int curl_errno ( resource $ch ) 返回最后一次cURL操作的错误号. 参数 ch 由 curl_init() 返回的 ...

  4. 求1+2+3.。。。n的和

    思路: 利用递归累加,逻辑运算符的短路运算. class Solution { public: int Sum_Solution(int n) { int result=n; result & ...

  5. linux 基础知识及命令总结

    1.mkdir   创建目录 -p 创建多级目录  mkdir -p /data/test -m, --mode=模式 设置权限模式(类似chmod),而不是rwxrwxrwx 减umask -p, ...

  6. 2018年最新Java面试题及答案整理(持续完善中…)

    2018年最新Java面试题及答案整理(持续完善中…) 基础篇 基本功 面向对象特征 封装,继承,多态和抽象 封装封装给对象提供了隐藏内部特性和行为的能力.对象提供一些能被其他对象访问的方法来改变它内 ...

  7. redis哨兵-5

    #地址: https://www.cnblogs.com/PatrickLiu/p/8444546.html #常用架构 redis1主1从+3哨兵 实现redis高可用 #redis主从 ##### ...

  8. docker 应用

    在ubuntu安装docker 编写Dockerfile (用来操作容器) FROM java:8 #获取java官方镜像 jdk版本为1.8 VOLUME /tmp # 数据存储目录,容器退出后数据 ...

  9. 《图解设计模式》读书笔记6-1 VISITOR模式

    目录 1. Visitor模式简介 2. 示例 2.1 类图 2.2 代码 3. 模式的角色和类图 4. 思路拓展 4.1 双重分发 4.2 开闭原则 4.3 难以增加ConcreteElement角 ...

  10. Yahoo! 35条网站性能优化建议

    Yahoo! 35条网站性能优化建议 Yahoo!的 Exceptional Performance团队为改善 Web性能带来最佳实践.他们为此进行了一系列的实验.开发了各种工具.写了大量的文章和博客 ...