Python格式化字符串的4中方式
一、%号
二、str.format(args)
三、f-Strings
四、标准库模板
五、总结四种方式的应用场景’
这是一种引入最早的一种,也是比较容易理解的一种方式.使用方式为:
1、格式化字符串中变化的部分使用占位符
2、变量以元组形式提供
3、变量与格式化字符串之间以%连接
ps:当需格式化的字符串过多时,位置极容易搞混
例如
a = 'zhangsan'
b = 'lisi'
print('%s eated %s' % (a, b)) # zhangsan eated lisi
print("%s asked %s to do something" % ("zhangsan", 'lisi')) # zhangsan asked lisi to do something
print("我的名字是%(name)s,我的年龄是%(age)s" % {"name": 'zhangsan', "age": "list"}) # 我的名字是zhangsan,我的年龄是list
kwargs = {"name": "zhangsan", "age": 18}
print("my name is %(name)s, my age is %(age)s" % kwargs) # my name is zhangsan, my age is 18
该format函数是在python2.6以后引入的,是字符吕类型的内置方法。因为str.format的方式
比%在性能和灵活性上更好一些。
按照位置一一对应
print("{} and {} is good friedng".format('zhangsan', 'lisi')) # zhangsan and lisi is good friedng
使用索引取对应位置的值
print('{0}{0}{1}{0}'.format('哈哈', '隔')) # 哈哈哈哈隔哈哈
可以通过关键字or字典方式的方式格式化,打破了位置带来的限制与困扰
print('我的名字是 {name}, 我的年龄是 {age}.'.format(age=18, name='egon'))
kwargs = {'name': 'egon', 'age': 18}
print("my name is {name}, my age is {age}".format(age=18, name="zhangsan"))
kwargs = {'name': 'zhangsan', "age": 18}
print("my name is {name}, my age is {age}".format(**kwargs)) # 使用**进行解包操作
先取到值,然后在冒号后面设定填充格式:[填充字符][对齐方式][宽度]
<20: 意思是: 左对齐,总共20个字符,不足部分用号填充
print("my name is {0:*<20},my age is {1:*<10}".format("zhangsan",
18)) # my name is zhangsan************,my age is 18********
# *>10: 右对齐,总共10个字符,不足部分用*填充
print("my name is {0:*<10}".format("zhangsan")) # my name is zhangsan**
# *^10: 居中,总共18个字符,不足部分用*填充
print("my name is {0:*^18}".format("zhangsan")) # my name is *****zhangsan*****
# ^20: 居中,总共20个字符,不足部分用空白填充
print("my name is {0:^20}".format("zhangsan")) # my name is zhangsan
print("{salary:.2f}".format(salary=123456.1234567)) # 123456.12精确到小数点后3位,四舍五入
print("{salary:.10f}".format(salary=123456.1234567)) # 123456.1234567890精确到小数点后3位,四舍五入
print("{:-^10.2f}".format(3.1415926)) # ---3.14--- 取2位小数后,居中,共10位,其余用-填充
print("{0:b}".format(123)) # 1111011 转成二进制
print("{0:o}".format(123)) # 173 转成八进制
print("{0:x}".format(123)) # 7b 转成十六进制
print("{0:,}".format(1234567)) # 1,234,567 千分位格式化
由python3.6版本引入的一个特性,称之为字面量格式化字符串
以F或者f开头,后面跟字符串,字符串中的表达式用大括号{}包起来,它会将变量或表达式计算后的值替换进去
f-string是以f或F开头的字符串, 核心在于字符串中符号{}的使用
name = ‘zhangsan’
print(f"my name is {name}") # my name is zhangsan
可以在{}中放置任意合法的表达式,会在运行时计算
print(f"{3 * 3 / 2}") # 4.5
a = 1
b = 2
print(f"a + b = {a + b}") # a + b = 3
比如 函数的调用
name = 'zhangsan'
print(F"my name is {name.upper()}") # my name is ZHANGSAN
def foo(n):
print("zhangsan is beautifull")
return n
print(F"{foo(10)}") # 10 执行时打印函数的返回值
# 在{}中使用‘或者” 保证{}内外使用的不一样即可,如下
print(F'test {"str"}') # teststr
print(F"test {'str'}") # teststr
# 在{}中需要同时使用’和“,则需要外部字符串使用文档字符串符号’‘’或者”“”
name = 'zhangsan'
print(F'''it's name is "{name}" ''') # it's name is "zhangsan" 注意各个’‘’是不一样的
print(F"{'{}'}") # 输出{} 注意两种引号不一样
# {}中不允许出现\即使作为函数参数;必须使用的话,可以将包含\的内容放到一个变量里,如下
a = 'zhangsan'
b = f'my name is {a:-^10}'
print(b) # my name is -zhangsan-
# a = f'print the {"\t"}'
# print(a) # 语法错误
a = '\n'
print(F"print the {a}") # print the \n没有显示 但打印正常
# f.str 格式可用于多行字符串,有两种方式:使用连接符\ 和使用doc签字串。如下
name = 'zhangsan '
age = 18
res = f'my name is {name},' \
F"my age is {age}," \
F"and i'm happy"
print(res) # my name is zhangsan ,my age is 18,and i'm happy
res = f'''my name is {name} ,my age is {age},and i'm happy,
my name is {name} ,my age is {age},and i'm happy
my name is {name} ,my age is {age},and i'm happy
my name is {name} ,my age is {age},and i'm happy'''
print(res) # 输出4行文本
这是string模块提供的一个模版类,默认使用$ 或者 ${}(建议用这个)来占位,而不是用%
具体用法如下
from string import Template
s = 'hi ${name}'
res = Template(s).substitute(name='zhangsan') # substitute替代品的意思
print(res) # hi zhangsan
# 当需要输出一个$符号时,可以使用$$
s1 = f'{name}‘s salary is $$1000'
res = Template(s1).substitute(name='zhangsan')
print(res)
# Template还有一个safe_substitute函数,
# 当格式化字符串中有变量未给出值时,此函数将占位符当成字符串输出,
# 而substitute会报错
name = 'zhangsan'
# s2 = f'{name} and {name2}‘s salary is $$1000'
# res = Template(s2).substitute()
# print(res) # 报错NameError: name 'name2' is not defined
#学习中遇到问题没人解答?小编创建了一个Python学习交流群:725638078
s3 = 'hi ${apple}, ${peach}'
res = Template(s3).safe_substitute(apple='apple')
print(res) # hi apple, ${peach}
性能对比
from timeit import timeit
def test_s():
name = 'zhangsan'
age = 18
return "%s:%s" % (name, age)
def test_format():
name = 'zhangsan'
age = 18
return '{}:{}'.format(name, age)
def test_f():
name = 'zhangsan'
age = 18
return f'{name}:{age}'
def test_t():
return Template('{name}:{age}').substitute(name='zhangsan', age=18)
res1 = timeit(test_s, number = 100000)
res2 = timeit(test_format, number = 100000)
res3 = timeit(test_f, number = 100000)
res4 = timeit(test_t, number = 100000)
print(res1) # 0.027567900004214607
print(res2) # 0.03230700000131037
print(res3) # 0.020800700003746897
print(res4) # 0.0893696999992244
看效率表现,还是 最新的f.str最快