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

var
X:integer;
p:^integer;
begin
X:=99;
p:=@X;
Edit1.Text:=Format('this is %p',[p]); //Edit1返回内容:this is 0012F548
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. 2019 GNTC 阿里云参会分享:开放、弹性的阿里云网络NFV平台

    作为全球规模最大的网络技术盛会之一,GNTC全球网络技术大会是网络技术发展的重要风向标,包含战略规划.产业方向.技术趋势.应用创新等皆汇集于此.而作为云服务商代表,阿里云再度受邀以顶级钻石合作伙伴之名 ...

  2. oracle集合的应用

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

  3. VB.NET导出Excel 轻松实现Excel的服务器与客户端交换 服务器不安装Office

    说来VB.Net这个也是之前的一个项目中用到的.今天拿来总结下用途,项目需求,不让在服务器安装Office办公软件.这个也是煞费了一顿. 主要的思路就是 在导出的时候,利用DataTable做中间变量 ...

  4. docker 应用

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

  5. 测开之路三十二:Flask基础之错误与重定向

    错误处理,框架默认的错误为:not Found 可以捕获,并自定义 准备一张自定义图片,放在static文件夹下,并在template下创建一个html文件,引用该图片 捕获404状态,返回自定义页面 ...

  6. python读取excel保存到mysql

    首先安装xlrd模块:pip install xlrd ,核心代码网上有很多,这里主要是关于一些个人实际碰到问题细节的处理 1.excel数据不规范导致读取的数据存在空白行和列: 2.参数化执行sql ...

  7. python+selenium+chromewebdriver或Firefox的环境搭建

    插件下载地址 chromewebdriver:https://chromedriver.storage.googleapis.com/index.html?path=2.26/放置在python下的S ...

  8. mysql中@ROW的使用

    一.从test02表中查询每个uid最早登录的前2天 表如下图所示: select * from (select uid,day, @ROW := END rn, @uuid:=uid from (s ...

  9. python基础--冒泡排序

    1.冒泡排序 1.首先用一张图来形象描述一下冒泡排序: 2.废话不多说,直接上代码 # 1.导入随机模块 import random # 2.定义一个列表,列表内的元素为20个100以内的随机整数 l ...

  10. java面试题-看到那记录到哪

    哈希冲突 如果两个不同的元素,通过哈希函数得到的实际存储地址相同怎么办?也就是说,当我们对某个元素进行哈希运算,得到一个存储地址,然后要进行插入的时候,发现已经被其他元素占用了,其实这就是所谓的哈希冲 ...