python 之 %s、%d、%f 的使用
复制代码
1 string=“hello”
2
3 #%s 打印时结果是 hello
4 print “string=%s” % string # output: string=hello
5
6 #%2s 意思是字符串长度为 2,当原字符串的长度超过 2 时,按原长度打印,所以 %2s 的打印结果还是 hello
7 print “string=%2s” % string # output: string=hello
8
9 #%7s 意思是字符串长度为 7,当原字符串的长度小于 7 时,在原字符串左侧补空格,
10 #所以 %7s 的打印结果是 hello
11 print “string=%7s” % string # output: string= hello
12
13 #%-7s 意思是字符串长度为 7,当原字符串的长度小于 7 时,在原字符串右侧补空格,
14 #所以 %-7s 的打印结果是 hello
15 print “string=%-7s!” % string # output: string=hello !
16
17 #%.2s 意思是截取字符串的前 2 个字符,所以 %.2s 的打印结果是 he
18 print “string=%.2s” % string # output: string=he
19
20 #%.7s 意思是截取字符串的前 7 个字符,当原字符串长度小于 7 时,即是字符串本身,
21 #所以 %.7s 的打印结果是 hello
22 print “string=%.7s” % string # output: string=hello
23
24 #%a.bs 这种格式是上面两种格式的综合,首先根据小数点后面的数 b 截取字符串,
25 #当截取的字符串长度小于 a 时,还需要在其左侧补空格
26 print “string=%7.2s” % string # output: string= he
27 print “string=%2.7s” % string # output: string=hello
28 print “string=%10.7s” % string # output: string= hello
29
30 #还可以用 %.s 来表示精度,两个的值分别在后面小括号的前两位数值指定
31 print "string=%.s" % (7,2,string) # output: string= he
复制代码
%d
复制代码
1 num=14
2
3 #%d 打印时结果是 14
4 print “num=%d” % num # output: num=14
5
6 #%1d 意思是打印结果为 1 位整数,当整数的位数超过 1 位时,按整数原值打印,所以 %1d 的打印结果还是 14
7 print “num=%1d” % num # output: num=14
8
9 #%3d 意思是打印结果为 3 位整数,当整数的位数不够 3 位时,在整数左侧补空格,所以 %3d 的打印结果是 14
10 print “num=%3d” % num # output: num= 14
11
12 #%-3d 意思是打印结果为 3 位整数,当整数的位数不够 3 位时,在整数右侧补空格,所以 %3d 的打印结果是 14_
13 print “num=%-3d” % num # output: num=14_
14
15 #%05d 意思是打印结果为 5 位整数,当整数的位数不够 5 位时,在整数左侧补 0,所以 %05d 的打印结果是 00014
16 print “num=%05d” % num # output: num=00014
17
18 #%.3d 小数点后面的 3 意思是打印结果为 3 位整数,
19 #当整数的位数不够 3 位时,在整数左侧补 0,所以 %.3d 的打印结果是 014
20 print “num=%.3d” % num # output: num=014
21
22 #%.0003d 小数点后面的 0003 和 3 一样,都表示 3,意思是打印结果为 3 位整数,
23 #当整数的位数不够 3 位时,在整数左侧补 0,所以 %.3d 的打印结果还是 014
24 print “num=%.0003d” % num # output: num=014
25
26 #%5.3d 是两种补齐方式的综合,当整数的位数不够 3 时,先在左侧补 0,还是不够 5 位时,再在左侧补空格,
27 #规则就是补 0 优先,最终的长度选数值较大的那个,所以 %5.3d 的打印结果还是 014
28 print “num=%5.3d” % num # output: num= 014
29
30 #%05.3d 是两种补齐方式的综合,当整数的位数不够 3 时,先在左侧补 0,还是不够 5 位时,
31 #由于是 05,再在左侧补 0,最终的长度选数值较大的那个,所以 %05.3d 的打印结果还是 00014
32 print “num=%05.3d” % num # output: num=00014
33
34 #还可以用 %.d 来表示精度,两个的值分别在后面小括号的前两位数值指定
35 #如下,不过这种方式 04 就失去补 0 的功能,只能补空格,只有小数点后面的 3 才能补 0
36 print “num=%*.*d” % (04,3,num) # output: num= 014
复制代码
%f
复制代码
1 import math
2
3 #%a.bf,a 表示浮点数的打印长度,b 表示浮点数小数点后面的精度
4
5 #只是 %f 时表示原值,默认是小数点后 5 位数
6 print “PI=%f” % math.pi # output: PI=3.141593
7
8 #只是 %9f 时,表示打印长度 9 位数,小数点也占一位,不够左侧补空格
9 print “PI=%9f” % math.pi # output: PI=_3.141593
10
11 #只有. 没有后面的数字时,表示去掉小数输出整数,03 表示不够 3 位数左侧补 0
12 print “PI=%03.f” % math.pi # output: PI=003
13
14 #%6.3f 表示小数点后面精确到 3 位,总长度 6 位数,包括小数点,不够左侧补空格
15 print “PI=%6.3f” % math.pi # output: PI=3.142
16
17 #%-6.3f 表示小数点后面精确到 3 位,总长度 6 位数,包括小数点,不够右侧补空格
18 print “PI=%-6.3f” % math.pi # output: PI=3.142
19
20 #还可以用 %.f 来表示精度,两个的值分别在后面小括号的前两位数值指定
21 #如下,不过这种方式 06 就失去补 0 的功能,只能补空格
22 print "PI=%.*f" % (06,3,math.pi) # output: PI=_3.142
复制代码
学习了。