格式 描述
%% 百分号标记 #就是输出一个%
%c 字符及其ASCII码
%s 字符串
%d 有符号整数(十进制)
%u 无符号整数(十进制)
%o 无符号整数(八进制)
%x 无符号整数(十六进制)
%X 无符号整数(十六进制大写字符)
%e 浮点数字(科学计数法)
%E 浮点数字(科学计数法,用E代替e)
%f 浮点数字(用小数点符号)
%g 浮点数字(根据值的大小采用%e或%f)
%G 浮点数字(类似于%g)
%p 指针(用十六进制打印值的内存地址)
%n 存储输出字符的数量放进参数列表的下一个变量中
%格式化符也可用于字典,可用%(name)引用字典中的元素进行格式化输出。
负号指时数字应该是左对齐的,“0”告诉Python用前导0填充数字,正号指时数字总是显示它的正负(+,-)符号,即使数字是正数也不例外。
可指定最小的字段宽度,如:”%5d” % 2。也可用句点符指定附加的精度,如:”%.3d” % 3。
例:
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
# 例:数字格式化 nYear = 2018 nMonth = 8 nDay = 18 # 格式化日期 %02d数字转成两位整型缺位填0 print '%04d-%02d-%02d'%(nYear,nMonth,nDay) >> 2018-08-18 # 输出结果 fValue = 8.123 print '%06.2f'%fValue # 保留宽度为6的2位小数浮点型 >> 008.12 # 输出 print '%d'%10 # 输出十进制 >> 10 print '%o'%10 # 输出八进制 >> 12 print '%02x'%10 # 输出两位十六进制,字母小写空缺补零 >> 0a print '%04X'%10 # 输出四位十六进制,字母大写空缺补零 >> 000A print '%.2e'%1.2888 # 以科学计数法输出浮点型保留2位小数 >> 1.29e+00 |
格式化操作符辅助指令
符号 作用
* 定义宽度或者小数点精度
- 用做左对齐
+ 在正数前面显示加号( + )
<sp> 在正数前面显示空格
# 在八进制数前面显示零(’0′),在十六进制前面显示’0x’或者’0X’(取决于
用的是’x'还是’X')
0 显示的数字前面填充‘0’而不是默认的空格
% ‘%%’输出一个单一的’%’
(var) 映射变量(字典参数)
m.n m 是显示的最小总宽度,n 是小数点后的位数(如果可用的话)
%s 字符串
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
string="hello" #%s打印时结果是hello print "string=%s" % string # output: string=hello #%2s意思是字符串长度为2,当原字符串的长度超过2时,按原长度打印,所以%2s的打印结果还是hello print "string=%2s" % string # output: string=hello #%7s意思是字符串长度为7,当原字符串的长度小于7时,在原字符串左侧补空格, #所以%7s的打印结果是 hello print "string=%7s" % string # output: string= hello #%-7s意思是字符串长度为7,当原字符串的长度小于7时,在原字符串右侧补空格, #所以%-7s的打印结果是 hello print "string=%-7s!" % string # output: string=hello ! #%.2s意思是截取字符串的前2个字符,所以%.2s的打印结果是he print "string=%.2s" % string # output: string=he #%.7s意思是截取字符串的前7个字符,当原字符串长度小于7时,即是字符串本身, #所以%.7s的打印结果是hello print "string=%.7s" % string # output: string=hello #%a.bs这种格式是上面两种格式的综合,首先根据小数点后面的数b截取字符串, #当截取的字符串长度小于a时,还需要在其左侧补空格 print "string=%7.2s" % string # output: string= he print "string=%2.7s" % string # output: string=hello print "string=%10.7s" % string # output: string= hello #还可以用%*.*s来表示精度,两个*的值分别在后面小括号的前两位数值指定 print "string=%*.*s" % (7,2,string) # output: string= he |
%d 整型
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
num=14 #%d打印时结果是14 print "num=%d" % num # output: num=14 #%1d意思是打印结果为1位整数,当整数的位数超过1位时,按整数原值打印,所以%1d的打印结果还是14 print "num=%1d" % num # output: num=14 #%3d意思是打印结果为3位整数,当整数的位数不够3位时,在整数左侧补空格,所以%3d的打印结果是 14 print "num=%3d" % num # output: num= 14 #%-3d意思是打印结果为3位整数,当整数的位数不够3位时,在整数右侧补空格,所以%3d的打印结果是14_ print "num=%-3d" % num # output: num=14_ #%05d意思是打印结果为5位整数,当整数的位数不够5位时,在整数左侧补0,所以%05d的打印结果是00014 print "num=%05d" % num # output: num=00014 #%.3d小数点后面的3意思是打印结果为3位整数, #当整数的位数不够3位时,在整数左侧补0,所以%.3d的打印结果是014 print "num=%.3d" % num # output: num=014 #%.0003d小数点后面的0003和3一样,都表示3,意思是打印结果为3位整数, #当整数的位数不够3位时,在整数左侧补0,所以%.3d的打印结果还是014 print "num=%.0003d" % num # output: num=014 #%5.3d是两种补齐方式的综合,当整数的位数不够3时,先在左侧补0,还是不够5位时,再在左侧补空格, #规则就是补0优先,最终的长度选数值较大的那个,所以%5.3d的打印结果还是 014 print "num=%5.3d" % num # output: num= 014 #%05.3d是两种补齐方式的综合,当整数的位数不够3时,先在左侧补0,还是不够5位时, #由于是05,再在左侧补0,最终的长度选数值较大的那个,所以%05.3d的打印结果还是00014 print "num=%05.3d" % num # output: num=00014 #还可以用%*.*d来表示精度,两个*的值分别在后面小括号的前两位数值指定 #如下,不过这种方式04就失去补0的功能,只能补空格,只有小数点后面的3才能补0 print "num=%*.*d" % (04,3,num) # output: num= 014 |
%f 浮点型
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
import math #%a.bf,a表示浮点数的打印长度,b表示浮点数小数点后面的精度 #只是%f时表示原值,默认是小数点后5位数 print "PI=%f" % math.pi # output: PI=3.141593 #只是%9f时,表示打印长度9位数,小数点也占一位,不够左侧补空格 print "PI=%9f" % math.pi # output: PI=_3.141593 #只有.没有后面的数字时,表示去掉小数输出整数,03表示不够3位数左侧补0 print "PI=%03.f" % math.pi # output: PI=003 #%6.3f表示小数点后面精确到3位,总长度6位数,包括小数点,不够左侧补空格 print "PI=%6.3f" % math.pi # output: PI=_3.142 #%-6.3f表示小数点后面精确到3位,总长度6位数,包括小数点,不够右侧补空格 print "PI=%-6.3f" % math.pi # output: PI=3.142_ #还可以用%*.*f来表示精度,两个*的值分别在后面小括号的前两位数值指定 #如下,不过这种方式06就失去补0的功能,只能补空格 print "PI=%*.*f" % (06,3,math.pi) # output: PI=_3.142 |