python format 冒号_python格式化输出函数之format

format相对于老版的%有很多优点

1.不需要理会数据类型

2.单个参数可以多次输出,参数顺序可以不同

3.填充方式十分灵活,对齐方式异常强大

4.官方推荐用的方式,%方式在后面的版本终将会被淘汰

一、str.format()方法会返回一个新的字符串,在新的字符串中,原字符串的替换字段被适当格式化后的参数替换,如下:

‘I love {0} ,I study {0} {1} years’.format(‘python’, 5) ==>I love python,I study python 5 years

format格式:

“{[field_name][!conversion][:][[fill]align][sign][#][0][width][,][.precision][type]}”.format()

1.字段名field_name

(1)每个替换字段由包含在花括号中的field_name标识的,如果field_name是简单的整数,就将被作为传递给str.format()的一个参数的索引位置,这种情况下,{0}、{1}..分别被format参数列表的第1、2….个参数代替,如果需要输出花括号,那就写两遍:{{0}}

(2)可以很容易连接字符串其他数据类型,当然也可以用来连接字符串,但最好用str.join

“I {0}{1}{2}”.format(‘你’,[1,2],(‘as’,3))===> “I 你[1, 2](‘as’, 3)”

(3)字段名为关键字参数的名称:关键字参数要在所有位置参数后

“{who} turned {age} this year”.format(who=’she’, age=88)==>she turned 88 this year

“the {who} was {0} this year”.format(12, who=’boy’)==>the boy was 12 this year

(4)字段名可以引用集合类型数据:利用列表、字符串、元组的索引

l=[‘python’, ‘c’, ‘c++’, ‘ruby’, ‘java’]

‘I learn {0[1]} first,then {0[2]} and {0[4]},finally I for in love with {0[0]}’.format(l) ==> ‘I learn c first,then c++ and java,finally I for in love with python’

(5)字典类型的参数:

d=dict(a=’hello’, b=’world’) =====>{“a”:”hello”, “b”:”world”}

“{0[a]} {0[b]}!!!”.format(d) ======>’hello world!!!’

这里需要注意的是:{0[a]}这里的a没有引号,加了会报错,但是如果是单纯的字典利用key取values的时候必须加引号:d[‘a’],d[‘b’]

(6)用句点引用参数的属性值

import math

“math.pi == {0.pi}”.format(math) ===>’math.pi == 3.141592653589793’

(7) py3.1以后,忽略字段名成为可能,这种情况下,Python会自动的进行处理

“{}:{}:{}”.format(‘a’,’b’,’c’) ===> ‘a:b:c’

(8)序列解析传参技术

“{0}{1}{2}”.format(*[1,2,3]) ==>’123’

“{0} {1}{2}”.format(*(‘hello’,’world’,3)) ==>’hello world3’

“{a} {b} {c}”.format(**{‘a’:’I’, ‘b’:’love’, ‘c’:’python’}) ===> ‘I love python’

2.转换conversion:!s !r !a

通过向字段中添加conversion指定符可以强制指定结果是以字符串形式输出还是以表象形式输出;有三个这种指定符:s,用于强制使用字符串形式,r,用于强制使用表象形式,a用于强制使用表象形式但仅限于ASCII字符:

import decimal

“{0} {0!s} {0!r} {0!a}”.format(decimal.Decimal(‘93.4’)) ==>”93.4 93.4 Decimal(‘93.4’) Decimal(‘93.4’)”

由于上面这个字符串仅由ASCII字符组成,所有!r和!a一样,下面这种方法可以阻止非ascii字符输出

“{0} {0!s} {0!r} {0!a}”.format(“我爱python”) ==>”我爱python 我爱python ‘我爱python’ ‘\u6211\u7231python’”

3.格式规约(这部分讲的是冒号之后的部分):[[fill]align][sign][#][0][width][,][.precision]

对于字符串而言,我们可以控制的包括填充字符、字段内对其方式、字段宽度(最大值、最小值)、整数分隔符(一般是逗号),浮点数精度控制

(1)fill填充字符可以是除{外的字符,一般可以是0,#,*等,但是只能为1个字符,这里需要注意的是如果指定了fill,就一定要指定对齐字符align,对齐有下面三种:向左对齐;居中对齐^;再之后为可选的最小宽度和最大宽度(最大宽度前面加上句点.)

例子:

s=’The sword of truth’

‘{0:25}’.format(s) ==> ‘The sword of truth ’

‘{0:>25}’.format(s) ==> ’ The sword of truth’

‘{0:<25}’.format(s) ==> ‘The sword of truth ’

‘{0:^25}’.format(s) ==> ’ The sword of truth ’

‘{0:-^25}’.format(s) ==> ‘—The sword of truth—-’

‘{0:#^25}’.format(s) ==> ‘###The sword of truth####’

‘{0:.<25}’.format(s) ==> ‘The sword of truth…….’

注意下面两种情况:

‘{0:.25}’.format(s) ===》’The sword of truth’

‘{0:.5}’.format(s) ===》’The s’

这里的句点不是填充符号,因为上面说过,fill必须和align一起出现,所以这里的句点表示的是最大宽度:

最小宽度为m 最大宽度为n 实际宽度为w

1) m、n>w 按最小宽度填充字符

‘{0:^5.6}’.format(‘123’) ==> ‘*123’

‘{0:^6.5}’.format(‘123’) ==> ‘*123*’

2)w>m、n截断

w>m>n ==> ‘{0:^6.5}’.format(‘1232345’) ==> ‘12323’

w>n>m ==> ‘{0:*^5.6}’.format(‘1232345’) ==> ‘123234’

3)m>w>n

‘{0:^6.4}’.format(‘12325’) ==> ‘*1232’

4)n>w>m

‘{0:*^4.6}’.format(‘12325’) ==> ‘12325’

5)单个

‘{0:*^4}’.format(‘12325’) ===> ‘12325’

‘{0:^6}’.format(‘12325’) ===>’12325’

‘{0:*^.4}’.format(‘12325’)===>’1232’

‘{0:*^.6}’.format(‘12325’)===> ‘12325’

(2)sign对于数字类型有效:+ -能在正数前面加上一个+,这个只需要记住他的位置就好了:[[fill]align][sign][#][0][width][,][.precision]

‘{0:#’+12325.343000#######’

‘{0:b} {0:o} {0:x} {0:X}’.format(1461287) ==>’101100100110000100111 5446047 164c27 164C27’

注意:他们参数只能是数字不能使字符串,这里的b、o、x分别是数字的二进制、八进制、16进制、d为10进制是默认情况可以不写。

在宽度后面可以加上一个逗号用于对整数分组

‘{0:,}’.format(1461287) ==> ‘1,461,287’

(3)对于浮点数的格式规约在结尾处有点差别,第一在可选最小宽度后面可以通过一个句点后跟一个整数指定保留小数的位数(包括小数点),也可以早结尾处添加一个类型符号:e表示使用指数形式,E是表示使用E指数形式,f表示使用标准的浮点形式,g表示通常格式,%会使数据扩大100倍后面加上%

“{0:-<10.6}”.format(math.pi)==》’3.14159—’

“{0:-<.5>

“{0:-<.5e>’3.14159e+02’

“{0:%}”.format(math.pi)==》’314.159265%’

(3)关于复数

“{0.real:.3f}{0.imag:+.3f}j”.format(4.2344+5.3445j) ==> ‘4.234+5.345j’

“{0.real:.3f}{0.imag:-.3f}j”.format(4.2344+5.3445j) ==> ‘4.234-5.345j’

前面的+-可以不写让他自己去判断:

“{0.real:.3f}{0.imag:.3f}j”.format(4.2344+5.3445j) ==> ‘4.234+5.345j’

“{0.real:.3f}{0.imag:.3f}j”.format(4.2344+5.3445j) ==> ‘4.234-5.345j’

————————————————

版权声明:本文为CSDN博主「py_tester」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/py_tester/article/details/78297628

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Pythonformat函数是一种字符串格式化的方法,它可以将特定的值插入到一个字符串中的占位符位置。使用format函数的一般语法如下: ```python formatted_string = "字符串{}".format(值) ``` 其中,`formatted_string`是格式化后得到的新字符串,`"字符串{}"`是带有占位符的原始字符串,`{}`是占位符,`值`是要插入到占位符位置的值。 format函数也支持多个占位符的情况,多个值可以按照顺序传入format函数。例如: ```python formatted_string = "姓名:{},年龄:{},性别:{}".format(name, age, gender) ``` 在format函数中,可以使用不同的格式规范来控制插入值的显示方式。例如,可以使用冒号`:`来指定要插入的值的显示格式。 例如,将一个整数作为占位符的值,可以指定宽度、对齐方式和填充字符等。例如: ```python formatted_string = "学生姓名:{:<10},学号:{:>10}".format(name, student_id) ``` 在上述的示例中,`{:}`中间的`<`表示左对齐,`10`表示宽度为10个字符,`>`表示右对齐。 此外,format函数还支持使用索引来指定占位符的值。例如: ```python formatted_string = "{0} versus {1}".format(team1, team2) ``` 在上述的示例中,`{0}`表示第一个值,`{1}`表示第二个值。 需要注意的是,format函数还支持其他更多的格式规范,如浮点数格式、日期格式等。具体的用法可以参考Python官方文档或相关教程。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值