python_format

python格式化的方法有两种:
百分号格式化和format格式化

1.百分号格式化:

%[(name)][flag][width].[precision]typecode
我们常用的:
%[(name)][flag][width].[precision]typecode
print("ginkgo is a %s man ,he is %d years old" % ("great", 20))
s = "ginkgo is a %s man ,he is %d years old" % ("great", 20)
s = "ginkgo is a %(n1)s man ,he is %(n2)d years old" % {"n1":"great","n2":20}
s = "ginkgo is a %(n1)-10s man ,he is %(n2)-5d years old" % {"n1":"great","n2":-20}
s = "ginkgo is a %(n1)-6s man ,he is %(n2)5.3f years old" % {"n1":"great","n2": 20.0000}
print(s)
注意,保留小数点位数必须是用浮点型的%f
  • name: 和%后边的字典生成对应关系,注意,当使用name时,后边就不再是元组,而是字典。当没有使用name时,后边跟的时元组。
  • flag: flag有5种方法:
 + 表示右对齐,正数前边加正号,负数前边加负号
 + 表示左对齐,正数前边不加号,负数前边加负号
0 表示右对齐,当使用width时,使用0填充
_  空格表示右对齐,正数前边加空格,负数前边加负号
  什么都没有,表示右对齐。
  • width: 表示宽度,也就是元组或字典内元素占有的宽度
  • .precision :表示保留几位小数,当使用此参数时,必须是浮点型%f
  • typecode:
s: 表示获取传入对象的_str_方法的返回值,并将其格式化到指定位置
r: 表示获取传入对象的_repr_方法的返回值,并将其格式化指定位置
c: 整数,将数字转换为unicode对应的值,10进制范围为 0 <= i <= 1114111(py27则只支持0-255);字符:将字符添加到指定位置

    s = "you are a %c" % 244
    print(s)
    result> you are a ô
o,x,d: 将数字转换成八进制,十六进制和十进制
e: 将整数、浮点数转换成科学计数法,并将其格式化到指定位置(小写e)
E: 将整数、浮点数转换成科学计数法,并将其格式化到指定位置(大写E)
f:将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)
F: 同上
g: 自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是e;)
G: 自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是E;)
%: 当字符串中存在一个格式化标志时,需要使用%%表示一个%号 
s = "The process is complete %d%%" % 20
print(s)
result >
The process is complete 20%

2.format格式化
基本语法是通过 {} 和 : 来代替以前的 %
在{}中冒号之前表示位置,冒号之后表示方法。
format 函数可以接受不限个参数,位置可以不按顺序。
format可以接受列表和字典

[[fill]align][sign][#][0][width][,][.precision][type]
  • fill: 对空白处填写的字符。
  • align: 对齐方式,需要配合width使用
< 左对齐
> 右对齐
= 内容右对齐,将符号放置在填充字符的左边,且仅对数字生效,即+/-##123
^ 居中对齐  
s = "a is {:#^10} boy ".format("good")
result> a is ###good### boy 
s = "a is {:#=10} boy ".format(-100)
result> a is -######100 boy 
  • sign: 符号数字
 + 正号加正,负号加负号
 + 正号不变,负号加负号
空格 正号加空格,负号加负
  • # 在输出2,8,16进制时,是否输出0b,0x,0o.如果不加,则不显示
  • , 表示可选分割符,用来分割数字,例如100,000
  • width 格式化位所占的宽度
  • .precision 浮点数保持的精度
  • type
    使用format表示%时,仅需要一个%就可以了,而且会自动将要格式化的数字转化为百分数
传入” 字符串类型 “的参数
s,格式化字符串类型数据
空白,未指定类型,则默认是None,同s
传入“ 整数类型 ”的参数
b,将10进制整数自动转换成2进制表示然后格式化
c,将10进制整数自动转换为其对应的unicode字符
d,十进制整数
o,将10进制整数自动转换成8进制表示然后格式化;
x,将10进制整数自动转换成16进制表示然后格式化(小写x)
X,将10进制整数自动转换成16进制表示然后格式化(大写X)
传入“ 浮点型或小数类型 ”的参数
e, 转换为科学计数法(小写e)表示,然后格式化;
E, 转换为科学计数法(大写E)表示,然后格式化;
f , 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
F, 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
g, 自动在e和f中切换
G, 自动在E和F中切换

%,显示百分比(默认显示小数点后6位)
s = "The loading process is {:.2%}".format(0.2)
result>
The loading process is 20.00%
  • format接受列表和字典
s = "i am {0},you are {1}".format("a","b")
s = "i am {0},you are {0}".format(*["a", "b"])
s = "i am {older},you are {younger}".format(**{"younger":"a", "older":"b"})
s = "i am {0[0]},you are {1[1]}".format(["a", "b"],["d", "e"])
result> i am a,you are b
        i am a,you are a
        i am b,you are a
        i am a,you are e
s = "numbers: {:b},{:o},{:d},{:x},{:X},{:.2f} {:.2%}".format(15, 15, 15, 15, 15, 15.87623, .2)
result > numbers: 1111,17,15,f,F,15.88 20.00%

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值