字符串格式化输出是python非常重要的基础语法,今天就把三种格式化输出做一个简单的总结,希望对大家有帮助。
格式化输出:内容按照一定格式要求进行输出。
python2.6版本之前,使用%格式化字符串沿用的是C语言的输出格式。
使用说明:
print("格式化字符串" % 变量)
变量超过2个使用元组格式:
print("格式化字符串" % (变量1,变量2))
使用%占位符表示字符串中变量位置,传入的值要与%占位符的变量一一对应
''' %s表示字符串, %d表示整数, %f表示小数(默认保留小数点后6位,%.2f保留两位小数), 存在格式化标志时,需要用 %%表示一个百分号。 ''' name='xiaoming' age=12 print("My name is %s,My age is %d" %(name,age)) #输出: My name is xiaoming,My age is 12
format是python2.6新增的一个格式化字符串的方法,相比%格式化方法有如下优点:
单个参数可以多次输出,参数顺序可以不相同,填充方式十分灵活,对齐方式十分强大,官方推荐用的方式
使用说明:
print("...{索引}, ... , {索引}, ...".format(值1, 值2))
#索引{}为空,默认按照顺序取值
print("...{key1}, ... , {key2}, ...".format(key1=value,key2=value))
name='xiaoming' age=12 print('My name is {}, My age is {}'.format(name,age)) print('My name is {0}, My age is {1}'.format(name,age)) print('My name is {name}, My age is {age}'.format(name='xiaoming',age=12)) #输出: My name is xiaoming,My age is 12
# 先取到值,然后在冒号后设定填充格式:{索引:[填充字符][对齐方式][宽度]}
# *<20:左对齐,总共20个字符,不够的用*号填充 rint('{0:*<20}'.format('hellopython')) # *>20:右对齐,总共20个字符,不够的用*号填充 print('{0:*>20}'.format('hellopython')) # *^20:居中显示,总共20个字符,不够的用*号填充 print('{0:*^20}'.format('hellopython')) 输出: hellopython********* *********hellopython ****hellopython*****
\#保留2位有效数字 print("{:.2f}".format(3.1415926)) \#转成二进制 print('{0:b}'.format(16)) \#转成八进制 print('{0:o}'.format(10)) \#转成十六进制 print('{0:x}'.format(15)) #既有填充对齐,又有位数保留 print("{:*<6.2f}".format(3.1415926)) #输出 3.14 10000 12 f 3.14**
在Python 3.6中引入 了f-strings,不仅比str.format使用简单,而且效率也更高。
使用说明
f-string是字符串前面加上 "f",{}直接使用变量、表达式等。
name='xiaoming' age=12 #{}中直接使用变量 print(f'My name is {name},My age is {age}') #{}中运行表达式 print(f'{1+2+3}') #调用Python内置函数 print(f'{name.upper()}') #用lambda匿名函数:可以做复杂的数值计算 fun = lambda x : x+1 print(f'{fun(age)}') #输出 My name is xiaoming,My age is 12 6 XIAOMING 13