Format 函数,%f,%d,%x,%p。 浮点型小数点位取值

来源:互联网 发布:淘宝必须升级企业店铺? 编辑:程序博客网 时间:2024/06/02 09:31

Format函数:返回按指定方式格式化一个数组常量的字符形式。
"%" [索引 ":"] ["-"] [宽度] ["." 摘要] 类型
Format('x=%d', [12]);                      //'x=12' //最普通
Format('x==', [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); //连接字符串

---------------------------------------------------------------------------------

--------------------------------------------------------

先来看看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]); //this is 0012F548
end;

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 M',[12]);//:this is   12; 这个是比较容易,不过如果Width的值小于

参数的长度,则没有效果。如:
Format('this is ',[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);

dddddd 以长时间格式显示年月日.FormatdateTime('dddddd',now);

e/ee/eee/eeee 以相应的位数显示年.FormatdateTime('ee',now);//输出为:10 (表示10年

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 分别表示小时,分,秒,毫秒

  以短时间格式显示时间.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);

也可以用":"来分开时间.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参数的用法
  这个指定相应的位数的指令。比如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('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来支配的
 

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 小中考地生没过怎么办 如果遇到不负责的语文老师怎么办 孩子的语文老师教的不好怎么办 刚买的小猫很凶怎么办 2月幼犬不吃东西怎么办 小狗狗不吃狗粮怎么办 母猫不会照顾小猫怎么办 刚买的小狗拉稀怎么办 母兔子吃小兔子怎么办 照片照出来背亮景人是黑的怎么办 手机透明壳变黄了怎么办 ae视频渲染太慢怎么办 3ce口红太干了怎么办 中考误用0.38mm的笔怎么办 ps画笔都锁住了怎么办 削铅笔机坏了怎么办 幼儿园小朋友不听老师话怎么办 孩子在幼儿园不听老师话怎么办 幼儿园大班孩子上课不好好上怎么办 脸上挠了血印子怎么办 大班公开课烫伤了怎么办教案 孩子心理出现了问题该怎么办 幼师打孩子很多家长告怎么办 课堂上纪律不好的学生怎么办 孩子上幼儿园总感冒怎么办 孩子上幼儿园总生病怎么办 台湾人抗拒统大陆人中国人怎么办 如果一年的公休日耍不完怎么办 我一个月要歇三天班怎么办 学校没给报到证怎么办 员工休息一天老板拉着脸怎么办 换工作了报到证怎么办 幼儿园的孩子不写作业怎么办 幼儿园宝宝不写作业怎么办 幼儿园孩子不写作业怎么办 光盘数据面写字了怎么办 娃娃的手断了怎么办 联币金融跑路了怎么办 胃消化不了想吐怎么办 吃撑了恶心想吐怎么办 mac口红膏体晃动怎么办