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:#<+20.6f}’.format(12325.343) ==>’+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}”.format(math.pi)==》’3.1416’
“{0:-<.5e}”.format(math.pi*100) ==>’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’

  • 12
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Python中的格式化输出是通过字符串的format()方法实现的。它可以将变量插入到字符串中,使输出更加灵活和易读。使用format()方法时,需要在字符串中使用花括号{}来表示要插入变量的位置,并在format()方法中传入相应的变量。例如: name = "小明" age = 18 print("我叫{},今年{}岁。".format(name, age)) 输出结果为:我叫小明,今年18岁。 在format()方法中,还可以使用格式化字符串来控制输出的格式。例如,可以使用{:d}来表示输出整数,{:f}来表示输出浮点数,{:s}来表示输出字符串等等。例如: num = 3.1415926 print("圆周率的值是{:.2f}。".format(num)) 输出结果为:圆周率的值是3.14。 除了使用花括号{}来表示要插入变量的位置外,还可以使用数字来表示要插入的变量的位置。例如: name = "小明" age = 18 print("我叫{},今年{1}岁。{}是个好名字。".format(name, age)) 输出结果为:我叫小明,今年18岁。小明是个好名字。 总之,Python中的格式化输出非常灵活和方便,可以根据需要随时调整输出的格式和内容。 ### 回答2: Python是一种强大的编程语言,其中一个强大的功能是利用字符串格式化输出数据,即format函数格式化输出是指将变量插入到字符串中的特定位置,结构化地显示数据,使之易于理解。 Python format() 函数的语法是:string.format()其中,string是要格式化的字符串,格式化参数可以是字符串、字典、元组或列表。格式化参数通常用花括号 {} 表示,可以指定参数的位置或者用名字来引用参数。 在进行格式化时,需要用一对大括号 {} 标示需要被替换的位置,格式化的参数列表依次填充大括号中的值,在大括号中可以指定参数的位置和名称,在大括号中添加“{数字}”来指定参数位置,数字表示参数在“format()”中的位置。 例如,“format("{} {} {}".format(a, b, c))”。 另外,括号中可以用名称来指定参数,名称需要在“format()”函数中指定。例如“format("{name}, {age}".format(name='张三', age=18))”。 format函数也可以用来限制输出的小数位数,例如“format("{:.2f}".format(3.1415926))”,将输出小数点后两位,结果为“3.14”。 除了支持字符串格式化之外,format函数还可以进行颜色渲染,使用方法为“\033[显示方式;字体色;背景色m”,例如红色字体输出为“\033[31m红色字体\033[0m”,其中的“\033[0m”表示恢复默认颜色。 总的来说,format函数Python中非常常用,可以用于字符串的格式化、颜色渲染等场景,使用灵活方便。需要掌握的技巧包括使用大括号{}指定参数位置或名称,指定小数位等等。 ### 回答3: Python语言是一款非常灵活的语言,能够对数据有效的进行处理,而格式化输出Python程序中非常重要的功能之一,而format就是Python语言中的字符串格式化,用于对字符串进行格式化输出Python中的format函数提供了一种非常灵活的方式来格式化字符串。通过使用大括号 {} 来指定要填充的值,同时还可以使用多个参数进行填充。 在编写Python程序时,可以使用format函数来指定输出的样式。 引号之间的文本就是格式字符串,可以包含相应的占位符,用来指定要输出的内容。占位符由大括号包裹,其中大括号中的内容可以包括一个格式化字段,格式化字段由一个或多个替换字段组成,替换字段可以用来指定不同的输出。 在format函数中,我们可以使用多种占位符来指定输出的格式,如 %d 表示输出一个整数, %f 表示输出一个小数,%s 表示输出一个字符串,%x 表示输出一个16进制数。此外,format函数还支持使用特定格式的占位符来对输出进行格式化显示,如 %06d 表示输出一个6位的数字不足补0。常用的格式化占位符如下: • %s:字符串格式。 • %d:整数格式。 • %f:浮点数格式。 • %o:八进制格式。 • %x:十六进制格式。 • %e:科学计数法格式(小写)。 • %E:科学计数法格式(大写)。 通过使用format函数,可以对Python程序中的数据进行格式化输出。使用format函数可以使输出更加美观,更加符合程序的需求。总的来说,format函数Python程序提供了一种强大的工具,使程序输出更为可读和可操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值