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 
对应浮点数 
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" yymmdd',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来支配的。

 
分类: C++转载

转;VC++中Format函数详解的更多相关文章

  1. JavaScript正则表达式详解(二)JavaScript中正则表达式函数详解

    二.JavaScript中正则表达式函数详解(exec, test, match, replace, search, split) 1.使用正则表达式的方法去匹配查找字符串 1.1. exec方法详解 ...

  2. 【转】linux 中fork()函数详解

    在看多线程的时候看到了这个函数,于是学习了下,下面文章写的通俗易懂,于是就开心的看完了,最后还是很愉快的算出了他最后一个问题. linux 中fork()函数详解 一.fork入门知识 一个进程,包括 ...

  3. Linux中fork()函数详解(转载)

    linux中fork()函数详解 一.fork入门知识 一个进程,包括代码.数据和分配给进程的资源.fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事, ...

  4. C++中重载函数详解

    函数的重载详解 什么时函数重载: 函数重载是指在同一作用域内,可以有一组具有相同函数名,不同参数列表的函数,这组函数被称为重载函数.重载函数通常用来命名一组功能相似的函数,这样做减少了函数名的数量,避 ...

  5. 我的第一个Python程序,定义主函数,eval、format函数详解,

    程序实例: #第一个py小程序 def main(): f = eval(input("输入一个数值:")) p=f*(5/9) print("现在的值为:{0:3.3f ...

  6. python中groupby函数详解(非常容易懂)

    一.groupby 能做什么? python中groupby函数主要的作用是进行数据的分组以及分组后地组内运算! 对于数据的分组和分组运算主要是指groupby函数的应用,具体函数的规则如下: df[ ...

  7. php中magic_quotes_gpc函数详解

    magic_quotes_gpc函数在php中的作用是判断解析用户提示的数据,如包括有:post.get.cookie过来的数据增加转义字符“\”,以确保这些数据不会引起程序,特别是数据库语句因为特殊 ...

  8. python unittest框架中addCleanup函数详解

    接上一篇doCleanups说明,这次介绍下另一个很好用的函数:addCleanup 还是老规矩,看官方文档说明: addCleanup(function, *args, **kwargs)¶ Add ...

  9. JavaScript基础内容中的函数详解

    函数 函数:即方法 函数就是一段预先设置的功能代码块,可以反复调用,根据输入参数的不同,返回不同的值. 为什么使用函数: 1.方便调用 2.代码重用,利于维护 3.便于修改,便于重构 4.简化逻辑,利 ...

随机推荐

  1. Migration workstation vms to openstack kvm

    Migration workstation vms to openstack kvm 分别分成(磁盘是否拆分,vms 是否 有多个磁盘驱动器) 1, linux迁移 vmware workstatio ...

  2. Java8 时间 API

    前言 Java8 中最为人津津乐道的新改变恐怕当属函数式 API 的加入.但实际上,Java8 所加入的新功能远不止这个. 本文将基于<Java SE8 for the Really Impat ...

  3. Java程序打包

    包名为 com.longneo.data,主程序入口为:com.longneo.data.AppMain 1.到工程目录下 /bin 执行 jar -cvf Demo.jar com 执行完之后会生成 ...

  4. (转)Maven实战(五)坐标详解

    1.为什么要定义Maven坐标      在我们开发Maven项目的时候,需要为其定义适当的坐标,这是Maven强制要求的.在这个基础上,其他Maven项目才能应用该项目生成的构件. 2.Maven坐 ...

  5. 字体在Android View中的输出 drawText

    Canvas 作为绘制文本时,使用FontMetrics对象,计算位置的坐标.   public static class FontMetrics {               public flo ...

  6. mysql去掉字段字符中间空格

    mysql有什么办法批量去掉某个字段字符中的空格?不仅是字符串前后的空格,还包含字符串中间的空格,答案是 replace,使用mysql自带的 replace 函数,另外还有个 trim 函数.   ...

  7. 微设计(www.weidesigner.com)介绍系列文章(二)

    微设计(www.weidesigner.com)是一个专门针对微信公众账号提供营销推广服务而打造的第三方平台. 2.1 怎样注冊微信公众号? 登录mp.weixin.qq.com,点击注冊填写相关信息 ...

  8. 用switch判断月份的练习

    import java.util.Scanner; public class SwitchTest01 { public static void main(String[] args) { Syste ...

  9. Atlas mysql的读写分离和负载均衡<转>

    mysql的读写分离和负载均衡 http://my.oschina.net/superbigfu/blog/178134

  10. 95秀-PullToRefreshListView 示例

        正在加载.暂无数据页面 public class RefreshGuideTool {     private RelativeLayout rl_loading_guide;//整个View ...