format的常用用法
【注:写神经网络的时候总是遇到输出loss、accuracy等,总是遇到以某种格式输出的内容,经常看到format这个东西,对于我这种小白,每次看到这种format输出的时候,总觉得很有逼格。so把format的用法去网上搜了一下,下面是我找的比较好的一个博客,我给转载过来了,仅供参考。当然下面很多内容还是捡需要的记,毕竟每个函数都有各种花里胡哨的参数和功能,不可能所有的你都会用到,还有一点就是我并没有在后面每个都打出输出结果,如果有兴趣的话,可以自己去print一下】
format是python2.6新增的一个格式化字符串的方法,相对于老版的%格式方法,它有很多优点。
1.不需要理会数据类型的问题,在%方法中%s只能替代字符串类型
2.单个参数可以多次输出,参数顺序可以不相同
3.填充方式十分灵活,对齐方式十分强大
4.官方推荐用的方式,%方式将会在后面的版本被淘汰
format的一个例子
1 | print 'hello {0}'.format('world') |
会输出hello world
一 填充
1.通过位置来填充字符串
1 2 3 | print 'hello {0} i am {1}'.format('Kevin','Tom') # hello Kevin i am Tom print 'hello {} i am {}'.format('Kevin','Tom') # hello Kevin i am Tom print 'hello {0} i am {1} . my name is {0}'.format('Kevin','Tom') # hello Kevin i am Tom . my name is Kevin |
foramt会把参数按位置顺序来填充到字符串中,第一个参数是0,然后1 ……
也可以不输入数字,这样也会按顺序来填充
同一个参数可以填充多次,这个是format比%先进的地方
2.通过key来填充
1 | print 'hello {name1} i am {name2}'.format(name1='Kevin',name2='Tom') # hello Kevin i am Tom |
3.通过下标填充
1 2 3 | names=['Kevin','Tom'] print 'hello {names[0]} i am {names[1]}'.format(names=names) # hello Kevin i am Tom print 'hello {0[0]} i am {0[1]}'.format(names) # hello Kevin i am Tom |
4.通过字典的key
1 2 | names={'name':'Kevin','name2':'Tom'} print 'hello {names[name]} i am {names[name2]}'.format(names=names) # hello Kevin i am Tom |
注意访问字典的key,不用引号的
5.通过对象的属性
1 2 3 4 5 | class Names(): name1='Kevin' name2='Tom'
print 'hello {names.name1} i am {names.name2}'.format(names=Names) # hello Kevin i am Tom |
6.使用魔法参数
1 2 3 | args=['lu'] kwargs = {'name1': 'Kevin', 'name2': 'Tom'} print 'hello {name1} {} i am {name2}'.format(*args, **kwargs) # hello Kevin i am Tom |
二 格式转换
b、d、o、x分别是二进制、十进制、八进制、十六进制。
数字 | 格式 | 输出 | 描述 |
3.1415926 | {:.2f} | 3.14 | 保留小数点后两位 |
3.1415926 | {:+.2f} | 3.14 | 带符号保留小数点后两位 |
-1 | {:+.2f} | -1 | 带符号保留小数点后两位 |
2.71828 | {:.0f} | 3 | 不带小数 |
1000000 | {:,} | 1,000,000 | 以逗号分隔的数字格式 |
0.25 | {:.2%} | 25.00% | 百分比格式 |
1000000000 | {:.2e} | 1.00E+09 | 指数记法 |
25 | {0:b} | 11001 | 转换成二进制 |
25 | {0:d} | 25 | 转换成十进制 |
25 | {0:o} | 31 | 转换成八进制 |
25 | {0:x} | 19 | 转换成十六进制 |
三 对齐与填充
数字 | 格式 | 输出 | 描述 |
5 | {:0>2} | 05 | 数字补零 (填充左边, 宽度为2) |
5 | {:x<4} | 5xxx | 数字补x (填充右边, 宽度为4) |
10 | {:x^4} | x10x | 数字补x (填充右边, 宽度为4) |
13 | {:10} | 13 | 右对齐 (默认, 宽度为10) |
13 | {:<10} | 13 | 左对齐 (宽度为10) |
13 | {:^10} | 13 | 中间对齐 (宽度为10) |
四 其他
1.转义{和}符号
1 | print '{{ hello {0} }}'.format('Kevin') |
跟%中%%转义%一样,formate中用两个大括号来转义
2.format作为函数
1 2 | f = 'hello {0} i am {1}'.format print f('Kevin','Tom') |
3.格式化datetime
1 2 | from datetime import datetime now=datetime.now() print '{:%Y-%m-%d %X}'.format(now) |
4.{}内嵌{}
1 | print 'hello {0:>{1}} '.format('Kevin',50) |
5.叹号的用法
!后面可以加s r a 分别对应str() repr() ascii()
作用是在填充前先用对应的函数来处理参数
1 2 | print "{!s}".format('2') # 2 print "{!r}".format('2') # '2' |
差别就是repr带有引号,str()是面向用户的,目的是可读性,repr()是面向python解析器的,返回值表示在python内部的含义
ascii()一直报错,可能这个是3.0才有的函数.
参考博客:https://blog.csdn.net/zhang89xiao/article/details/53818906