详细讲述各种占位符的应用
# -*- coding:utf-8 -*-
# @Author: CH
"""
@project: python study
@time:
@detail:
@else: DO NOT STOP STUDYING!!!
"""
#%s 字符串
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 整型
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= 01
#%f 浮点型
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
网友评论