Python的字符串格式化有两种方式: 百分号方式、format方式

百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存。

 

1、百分号方式格式化字符串

%[(name)][flags][width].[precision]typecode必选

 

typecode 必选

如:

%s字符串格式化拼接,将几个字符串拼接在一起%s为占位符,就是占位的作用,主意:占位符与占位符之间还可以加一个分隔符
%()引用数据到占位符
如果有几个字符串需要拼接
拼接格式:
"占位符要引用几个字符串就写几个占位符" %(要引用的字符串变量)



#!/usr/bin/env python
# -*- coding:utf8 -*-
"""
%s字符串格式化拼接,将几个字符串拼接在一起
%s为占位符,就是占位的作用,主意:占位符与占位符之间还可以加一个分隔符
%()引用数据到占位符
如果有几个字符串需要拼接
拼接格式:
"占位符要引用几个字符串就写几个占位符" %(要引用的字符串变量)
"""
a = "你好"
b = "我好"
c = "大家好"
d = "%s%s%s" %(a, b, c)
print(d)
#输出
#你好我好大家好



typecode的方法有以下几种

s,获取传入对象的__str__方法的返回值,并将其格式化到指定位置,能接受各种类型
r,获取传入对象的__repr__方法的返回值,并将其格式化到指定位置
c,整数:将数字转换成其unicode对应的值,10进制范围为 0 <= i <= 1114111(py27则只支持0-255);字符:将字符添加到指定位置
o,将整数转换成 八 进制表示,并将其格式化到指定位置
x,将整数转换成十六进制表示,并将其格式化到指定位置
d,将整数、浮点数转换成 十 进制表示,并将其格式化到指定位置
e,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(小写e)
E,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(大写E)
f, 将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)
F,同上
g,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是e;)
G,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是E;)
%,当字符串中存在格式化标志时,需要用 %%表示一个百分号
注:Python中百分号格式化是不存在自动将整数转换成二进制表示的方式

 

(name)可选,用于选择指定的key,就是给占位符设置一个名称,字典传值对应的占位符,也就是可以自定义传值位置

如:%(n1)s



#!/usr/bin/env python
# -*- coding:utf8 -*-
a = "百分%(n2)s的方式相%(n1)s来说比较老" % {"n1":"对", "n2":"号"}    #可选,用于选择指定的key,就是给占位符设置一个名称,字典传值对应的占位符,也就是可以自定义传值位置
print(a)
#输出
# 百分号的方式相对来说比较老



 

flags可选,可供选择的值有,左对齐或者右对齐,一般配合width使用

  + 右对齐;正数前加正好,负数前加负号;

  如:flags:%+s  width:10 

    配合:%+10s  右对齐10个字符,就是占位符在10个空白字符的右边



#!/usr/bin/env python
# -*- coding:utf8 -*-
a = "百分%+10s的方式相%s来说比较老" % ("号","对")   #配合:%+10s  右对齐10个字符,就是占位符在10个空白字符的右边
print(a)
#输出
# 百分         号的方式相对来说比较老



 - 左对齐;正数前无符号,负数前加负号;



#!/usr/bin/env python
# -*- coding:utf8 -*-
a = "百分%-10s的方式相%s来说比较老" % (-20,"对")   #左对齐10的宽度,数字类型负数自动加负号
print(a)
#输出
# 百分-20       的方式相对来说比较老



  空格 右对齐;正数前加空格,负数前加负号;



#!/usr/bin/env python
# -*- coding:utf8 -*-
a = "百分% 10s的方式相%s来说比较老" % (-20,"对")   #右对齐10的宽度,数字类型负数自动加负号
print(a)
#输出
# 百分       -20的方式相对来说比较老



  0 右对齐;正数前无符号,负数前加负号;用0填充空白处,0填充只有传值数字有效



#!/usr/bin/env python
# -*- coding:utf8 -*-
a = "百分%010s的方式相%s来说比较老" % (-20,"对")   #右对齐10的宽度,数字类型负数自动加负号
print(a)
#输出
# 百分       -20的方式相对来说比较老



 

width可选,占有宽度,占位符占位宽度,一般配合flags使用

如:flags:%+s  width:10 

    配合:%+10s  右对齐10个字符,就是占位符在10个空白字符的右边



#!/usr/bin/env python
# -*- coding:utf8 -*-
a = "百分%+10s的方式相%s来说比较老" % ("号","对")   #配合:%+10s  右对齐10个字符,就是占位符在10个空白字符的右边
print(a)
#输出
# 百分         号的方式相对来说比较老



 

precision 可选,小数点后保留的位数

.1 浮点数保留1位,点后面写几就保留几位

如:%.1f

 



#!/usr/bin/env python
# -*- coding:utf8 -*-
a = "百分%.1f的方式相来说比较老" % (1.20000)   #小数点后保留的位数,.1 浮点数保留1位,点后面写几就保留几位
print(a)
#输出
# 百分1.2的方式相来说比较老



 

常用格式化:重点



# -*- coding:utf8 -*-
tp1 = "i am %s" % ("alex")
print(tp1)
tp2 = "i am %s age %d" % ("alex", 18)
print(tp2)
tp3 = "i am %(name)s age %(age)d" % {"name": "alex", "age": 18}
print(tp3)
tp4 = "percent %.2f" % 99.97623
print(tp4)
tp5 = "i am %(pp).2f" % {"pp": 123.425556, }
print(tp5)
tp6 = "i am %(pp).2f %%" % {"pp": 123.425556, }
print(tp6)
#输出
# i am alex
# i am alex age 18
# i am alex age 18
# percent 99.98
# i am 123.43
# i am 123.43 %



 注:Python中百分号格式化是不存在自动将整数转换成二进制表示的方式

 

 2、Format方式格式化字符串【推荐】

[[fill]align][sign][#][0][width][,][.precision][type]   Format方式都是可选的  有这九种方法

 

format 方式格式化字符串,是在字符串里加{}大括号作为占位符,在字符串后面.format("要引用的字符串"或变量)

如:"这是一{}字{}串".format("段","符")



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{}字{}串".format("段","符")
print(tp1)
#输出
#这是一段字符串



 

fill【可选】空白处填充的字符,一般需要配合align和width使用

如:fill:填充*  align:对齐方式  width:宽度10个字符

结合:{:*>10}



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:*>10}字{}串".format("段","符")  #空白处填充的字符,一般需要配合align和width使用
print(tp1)
#输出
#这是一*********段字符串



 

align【可选】对齐方式(需配合width使用)
<,内容左对齐



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:<10}字{}串".format("段","符")  #内容左对齐,10个字符宽度
print(tp1)
#输出
#这是一段         字符串



>,内容右对齐(默认)



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:>10}字{}串".format("段","符")  #内容右对齐,10个字符宽度
print(tp1)
#输出
#这是一         段字符串



=,内容右对齐,将符号放置在填充字符的左侧,且只对数字类型有效。 即使:符号+填充物+数字



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:|=10}字{}串".format(2,"符")  #内容右对齐,10个字符宽度
print(tp1)
#输出
#这是一|||||||||2字符串



^,内容居中

 



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:|^10}字{}串".format("段","符")  #内容居中,10个字符宽度
print(tp1)
#输出
#这是一||||段|||||字符串



 

 

sign【可选】有无符号数字
+,正号加正,负号加负;



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:+}字{}串".format(20,"符")  #正号加正,负号加负;
print(tp1)
#输出
#这是一+20字符串



-,正号不变,负号加负;



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:-}字{}串".format(20,"符")  #正号不变,负号加负
print(tp1)
#输出
#这是一20字符串



空格 ,正号空格,负号加负;

 



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{: }字{}串".format(20,"符")  #空格 ,正号空格,负号加负
print(tp1)
#输出
#这是一 20字符串



 

 

#【可选】对于二进制、八进制、十六进制,如果加上#,会显示 0b/0o/0x,否则不显示

#需要结合type的进制  如:#b

 



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:#b}字{}串".format(20,"符")  #对于二进制、八进制、十六进制,如果加上#,会显示 0b/0o/0x,否则不显示
print(tp1)
#输出
#这是一0b10100字符串



 

 

,【可选】为数字添加分隔符,如:1,000,000 像银行系统余额类型

如:把1000 转换成1,000

 



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:,}字{}串".format(1000,"符")  #【可选】为数字添加分隔符,如:1,000,000 像银行系统余额类型
print(tp1)
#输出
#这是一1,000字符串



 

 

width【可选】格式化位所占宽度



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:10}字{}串".format(1000,"符")  #【可选】格式化位所占宽度,10个字符宽度
print(tp1)
#输出
#这是一      1000字符串



 

.precision 【可选】小数位保留精度,一般结合type类型使用

如:{:.2f} 小数保留两位



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:.2f}字{}串".format(10.233,"符")  #.precision 【可选】小数位保留精度,一般结合type类型使用
print(tp1)
#输出
#这是一10.23字符串



 

type【可选】格式化类型

传入” 字符串类型 “的参数
  s,格式化字符串类型数据



#!/usr/bin/env python
# -*- coding:utf8 -*-
tp1 = "这是一{:s}字{}串".format("段","符")  #s,格式化字符串类型数据
print(tp1)
#输出
#这是一段字符串



  空白,未指定类型,则默认是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位)

 

常用格式化:重点

依次对应接收字符串和数字



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {}, age {}, {}".format("seven", 18, 'alex')  #依次对应接受字符串和数字
print(tpl)
#输出
#i am seven, age 18, alex



 

依次对应接收列表里的元素,列表前加一个*表示列表里可以是若干元素



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {}, age {}, {}".format(*["seven", 18, 'alex',20])  #依次对应接收列表里的元素,列表前加一个*表示列表里可以是若干元素
print(tpl)
#输出
#i am seven, age 18, alex



 

索引方式接收字符串或数字



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {0}, age {1}, really {0}".format("seven", 18)  #索引方式接收字符串或数字
print(tpl)
#输出
#i am seven, age 18, really seven



 

索引方式接收列表里的元素,列表前加*表示列表里的元素可以是若干



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {0}, age {1}, really {0}".format(*["seven", 18, 20])  #索引方式接收列表里的元素,列表前加*表示列表里的元素可以是若干
print(tpl)
#输出
#i am seven, age 18, really seven



 

以键来接收,键值对里的值



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {name}, age {age}, really {name}".format(name="seven", age=18)  #以键来接收,键值对里的值
print(tpl)
#输出
#i am seven, age 18, really seven



 

以键来接收字典里对应的值,字典前加**表示字典里可以是若干元素



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {name}, age {age}, really {name}".format(**{"name": "seven", "age": 18, "n1":12})  #以键来接收字典里对应的值,字典前加**表示字典里可以是若干元素
print(tpl)
#输出
#i am seven, age 18, really seven



 

以索引里的索引来接收值



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {0[0]}, age {0[1]}, really {0[2]}".format([1, 2, 3], [11, 22, 33])  #以索引里的索引来接收值
print(tpl)
#输出
#i am 1, age 2, really 3



 

以type类型接收值



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {:s}, age {:d}, money {:f}".format("seven", 18, 88888.1)  #以type类型接收值
print(tpl)
#输出
#i am seven, age 18, money 88888.100000



 

以type类型接收列表里的值,列表前加*表示列表里的元素可以是若干



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {:s}, age {:d}".format(*["seven", 18])  #以type类型接收列表里的值,列表前加*表示列表里的元素可以是若干
print(tpl)
#输出
#i am seven, age 18



 

以键名称加type类型接收,对应的键值对的值



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {name:s}, age {age:d}".format(name="seven", age=18)  #以键名称加type类型接收,对应的键值对的值
print(tpl)
#输出
#i am seven, age 18



 

以键名称加type类型,接收字典里的值,字典前面加**表示字典里的元素可以是若干



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "i am {name:s}, age {age:d}".format(**{"name": "seven", "age": 18})  #以键名称加type类型,接收字典里的值,字典前面加**表示字典里的元素可以是若干
print(tpl)
#输出
#i am seven, age 18



 

以多种type类型,来接收数字转换成对应的类型



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)  #以多种type类型,来接收数字转换成对应的类型
print(tpl)
#输出
#numbers: 1111,17,15,f,F, 1587.623000%



 

以多种type类型接收一个数字,转换成对应的类型



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "numbers: {0:b},{0:o},{0:d},{0:x},{0:X}, {0:%}".format(15)  #以多种type类型接收一个数字,转换成对应的类型
print(tpl)
#输出
#numbers: 1111,17,15,f,F, 1500.000000%



 

以键名称加多种type类型,接收一个键值对的值转换成对应的类型



#!/usr/bin/env python
# -*- coding:utf8 -*-
tpl = "numbers: {num:b},{num:o},{num:d},{num:x},{num:X}, {num:%}".format(num=15)  #以键名称加多种type类型,接收一个键值对的值转换成对应的类型
print(tpl)
#输出
#numbers: 1111,17,15,f,F, 1500.000000%