Python 中的三种字符串格式化方式:% 格式化字符、str.format方法、f-string函数

Python 中的三种字符串格式化方式:% 格式化字符、str.format() 方法 和 f-string(f 函数)

Python 提供了三种常用的字符串格式化方式,每种方式都有其特点、优点和适用场景。

以下是这三种方式的比较和说明:

1. 格式化字符(% 格式化)

% 格式化:适用于简单格式化,尤其是兼容旧代码时使用。

1.1 优缺点,使用场景

优点:

  • 简单直接:语法简单,适用于简单的格式化需求。
  • 历史遗留:这是最早的字符串格式化方式,Python 早期版本就已支持。

缺点

  • 不支持表达式:不能在 % 中进行计算或嵌入复杂的表达式。
  • 易出错:如果格式标志和变量类型不匹配,容易发生错误。

不支持关键字参数:只能按位置传递参数,无法直接使用关键字。

适用场景
用于简单的格式化和老旧代码的维护。

1.2 % 格式化字符详细说明

以下是常用的格式化字符的详细说明、用法以及对应场景:

格式字符含义用法示例输出结果使用场景
%c单个字符'%c' % 65A输出字符,适合处理字符和Unicode编码。
%s字符串'%s' % 'Hello'Hello输出字符串,适合字符串拼接与动态输出。
%d有符号十进制整数'%d' % -123-123输出整数,适合处理整数类型的数据。
%u无符号十进制整数(已过时,与%d相同)'%u' % 123123适用于旧代码兼容,但推荐使用%d
%o八进制整数'%o' % 255377输出八进制数,适合文件权限、地址等场景。
%x十六进制整数(小写字母)'%x' % 255ff输出小写十六进制数,适合处理内存地址等数据。
%X十六进制整数(大写字母)'%X' % 255FF输出大写十六进制数,适合处理内存地址等数据。
%f浮点数,默认保留6位小数'%f' % 3.141593.141590输出浮点数,适合小数精度控制与科学计算。
%e科学计数法(小写e)'%e' % 1234567.891.234568e+06输出科学计数法,适合处理较大或较小的数值。
%E科学计数法(大写E)'%E' % 1234567.891.234568E+06同上,仅字母为大写,适合科学报告的输出格式。
%g自动选择%f%e'%g' % 0.0000123451.2345e-05根据数值大小自动选择最简洁的显示方式。
%G自动选择%f%E'%G' % 123456789.01.23457E+08同上,适合更简洁和更高端的格式化需求。

1.3 什么是宽度?

宽度是指输出内容占用的字符数(包括空格、符号等),主要用于对齐输出结果。宽度不足时,默认用空格填充,特殊情况下可以指定用 0 或其他字符填充。

示例:

print("%5d" % 12)   # 宽度为5,右对齐,输出: "   12" (前面填充3个空格)
print("%-5d" % 12)  # 宽度为5,左对齐,输出: "12   " (后面填充3个空格)
print("%05d" % 12)  # 宽度为5,右对齐,前面用0填充,输出: "00012"

1.4 格式化字符语法

# 格式化输出:按照我们自己想要输出的格式,先定义一个板,照着板输出
# 格式化输出思路:首先定义模板,然后照着模板把变量填进去
# 格式化输出语法: print(模板 %变量名)

1.5 格式化字符(% 格式化)示例代码

# 1. %c:输出单个字符
# 用法:可以传入字符或对应的 ASCII/Unicode 编码。
# 场景:适用于字符的显示,支持 Unicode 字符。
print("%c" % 65)  # 输出: A (ASCII码为65)
print("%c" % 0x4F60)  # 输出: 你 (Unicode编码为0x4F60)
print("--------------------------------------------------------------------------------------------------------------")

# 2. %s:输出字符串
# 用法:动态输出字符串,可配合宽度(宽度不足时,默认用空格填充)、对齐使用。
# 场景:适用于字符串拼接和格式化输出。
print("%10s" % "Hello")  # 输出:      Hello (宽度10,右对齐)
print("%-10s" % "World")  # 输出: World      (宽度10,左对齐)
print("--------------------------------------------------------------------------------------------------------------")

# 3. %d:输出带符号的十进制整数
# 用法:支持正负数,可指定宽度和填充方式。
# 场景:适用于整数类型的格式化输出,如统计数据。
print("%5d" % 42)  # 输出:    42 (宽度5,右对齐)
print("%-5d" % 42)  # 输出: 42   (宽度5,左对齐)
print("%05d" % 42)  # 输出: 00042 (宽度5,前面补0)
print("--------------------------------------------------------------------------------------------------------------")

# 4. %o:输出八进制整数
# 用法:将整数转换为八进制表示。
# 场景:适用于权限值、位运算等相关场景。
print("%o" % 255)  # 输出: 377 (255的八进制表示)
print("%06o" % 255)  # 输出: 000377 (宽度6,前面补0)
print("--------------------------------------------------------------------------------------------------------------")

# 5. %x 和 %X:输出十六进制整数
# 用法:小写字母用%x,大写字母用%X。
# 场景:适用于内存地址、颜色编码等。
print("%x" % 255)  # 输出: ff (小写十六进制)
print("%X" % 255)  # 输出: FF (大写十六进制)
print("%04x" % 255)  # 输出: 00ff (宽度4,前面补0)
print("--------------------------------------------------------------------------------------------------------------")

# 6. %f:输出浮点数
# 用法:默认保留6位小数,可指定精度和宽度。
# 场景:适用于小数点精度控制与科学计算。
print("%f" % 3.14159)  # 输出: 3.141590 (默认6位小数)
print("%.2f" % 3.14159)  # 输出: 3.14 (保留2位小数)
print("%10.3f" % 3.14159)  # 输出:      3.142 (宽度10,保留3位小数)
print("--------------------------------------------------------------------------------------------------------------")

# 7. %e 和 %E:输出科学计数法
# 用法:%e使用小写e,%E使用大写E。
# 场景:适用于较大或较小的数值表示。
print("%e" % 1234567.89)  # 输出: 1.234568e+06
print("%E" % 1234567.89)  # 输出: 1.234568E+06
print("%.3e" % 0.0000123)  # 输出: 1.230e-05 (保留3位小数)
print("--------------------------------------------------------------------------------------------------------------")

# 8. %g 和 %G:自动选择最简洁的格式
# 用法:%g会在%f和%e之间选择,%G会在%f和%E之间选择。
# 场景:适用于需要简洁表示数值的情况。
print("%g" % 0.000012345)  # 输出: 1.2345e-05 (小数形式太长时用科学计数法)
print("%g" % 123456.78)  # 输出: 123457 (自动去掉多余的零)
print("%.3g" % 123456.78)  # 输出: 1.23e+05 (保留3位有效数字)
print("--------------------------------------------------------------------------------------------------------------")

2. str.format方法

在 Python 中,format 是一个强大的字符串格式化工具,它提供了比传统的 % 格式化方法更灵活和可读的方式来处理字符串插值。format 可以对字符串中的占位符进行动态替换,支持位置参数、关键字参数以及格式化控制等功能。

2.1 优缺点,使用场景

优点:

  • 更灵活:可以按位置或关键字参数传递格式化的值。
  • 支持表达式:可以在 {} 中嵌入表达式计算。
  • 更清晰:格式化语法比 % 更加清晰,并且支持多次引用同一个变量。

缺点:

  • 略显冗长:虽然比 % 更灵活,但仍然比 f-string 少了一些简洁性。
  • 性能较差:相较于 f-stringstr.format() 在性能上稍逊一筹,尤其是在高频格式化的场景下。

适用场景:
当需要格式化多个变量,或者需要用关键字来标识位置时。

2.2 str.format 语法

"模板字符串".format(参数1, 参数2, ...)

占位符使用 {},其中的内容可以是参数的索引、命名、格式化标志等。

2.3 str.format 示例代码

# 定义一些变量用于演示
name = "Bob"  # 姓名
age = 25      # 年龄
height = 1.75  # 身高

# 1. 使用位置参数,格式化字符串
# 使用 `{0}`, `{1}`, `{2}` 来标识位置参数的顺序,替换成对应的变量
print("My name is {0}, I am {1} years old and {0} is {2} meters tall.".format(name, age, height))
# 输出:My name is Bob, I am 25 years old and Bob is 1.75 meters tall.
print("--------------------------------------------------------------------------------------------------------------")

# 2. 使用关键字参数,格式化字符串
# 使用 `{name}`, `{age}`, `{height}` 来直接使用关键字参数,替换对应的值
print("My name is {name}, I am {age} years old and {name} is {height} meters tall.".format(name="Bob", age=25, height=1.75))
# 输出:My name is Bob, I am 25 years old and Bob is 1.75 meters tall.
print("--------------------------------------------------------------------------------------------------------------")

# 3. 使用字典解包,格式化字符串
# 使用 `**` 解包字典并传递给 `format` 函数,字典中的键值对应于占位符的名字
person_info = {'name': 'Alice', 'age': 30, 'height': 1.68}
print("My name is {name}, I am {age} years old and my height is {height} meters.".format(**person_info))
# 输出:My name is Alice, I am 30 years old and my height is 1.68 meters.
print("--------------------------------------------------------------------------------------------------------------")

# 4. 格式化数字
# 使用 `:.3f` 表示将数字格式化为浮动小数点类型,并保留三位小数
pi = 3.14159265358979
print("The value of pi to 3 decimal places is {:.3f}".format(pi))
# 输出:The value of pi to 3 decimal places is 3.142
print("--------------------------------------------------------------------------------------------------------------")

# 5. 对齐和填充
# `:<10`:左对齐,占10个字符宽度,不足部分用空格填充
# `:>10`:右对齐,占10个字符宽度,不足部分用空格填充
# `:^10`:居中对齐,占10个字符宽度,不足部分用空格填充
# `:0>10`:右对齐,占10个字符宽度,不足部分用零填充
text = "Python"
print("{:<10}".format(text))  # 左对齐
print("{:>10}".format(text))  # 右对齐
print("{:^10}".format(text))  # 居中对齐
print("{:0>10}".format(text))  # 使用 0 填充,右对齐
# 输出:
# Python
#     Python
#   Python
# 000000Python
print("--------------------------------------------------------------------------------------------------------------")

# 6. 对数字进行补充和格式化
# 对数值进行千位分隔符的格式化
num = 1234567.89
print("Formatted number: {:,}".format(num))
# 输出:Formatted number: 1,234,567.89
print("--------------------------------------------------------------------------------------------------------------")

# 7. 使用浮动精度格式化
# 控制浮动小数的精度显示
number = 123.45678
print("Formatted float: {:.2f}".format(number))  # 显示两位小数
# 输出:Formatted float: 123.46
print("--------------------------------------------------------------------------------------------------------------")

# 8. 使用宽度和填充
# 填充字符串并指定最小宽度
print("{:>10}".format("hello"))  # 右对齐,宽度为10
print("{:<10}".format("world"))  # 左对齐,宽度为10
# 输出:
#      hello
# world
print("--------------------------------------------------------------------------------------------------------------")

# 9. 使用多个格式化参数
# 在同一个字符串中使用多个占位符来显示不同的内容
print("Name: {0}, Age: {1}, Height: {2:.2f}".format(name, age, height))
# 输出:Name: Bob, Age: 25, Height: 1.75
print("--------------------------------------------------------------------------------------------------------------")

3. f-string(f 函数)

在 Python 中,f 函数是指 f-string(格式化字符串字面量),用于简化字符串格式化的过程。通过 f-string,您可以将变量或表达式直接嵌入到字符串中。它在 Python 3.6 引入,并成为了推荐的字符串格式化方法。

3.1 优缺点,使用场景

优点:

  • 最简洁:语法最简洁,直接在字符串中嵌入变量或表达式。
  • 高效:相较于 %str.format()f-string 在性能上通常是最好的,特别是在大规模数据格式化时。
  • 支持表达式:可以嵌入任意 Python 表达式(如计算、函数调用等)。
  • 代码可读性高:格式化语法更直观,易于理解和维护。

缺点:

  • 仅支持 Python 3.6 及以上f-string 是在 Python 3.6 引入的,因此不兼容低版本的 Python。
  • 只能用于字符串f-string 只能用来格式化字符串,不能直接用于其他类型。

适用场景:
Python 3.6 及以上版本,尤其适用于需要频繁进行字符串格式化的场景。

3.2 f-string 语法

f"字符串 {表达式}"
  • f:表示这是一个格式化字符串。
  • {}:内部的部分可以是任何合法的 Python 表达式(包括变量、函数调用、算术运算等)。

使用场景

  1. 嵌入变量值:直接将变量插入到字符串中。
  2. 表达式计算:不仅可以嵌入变量,还可以在 {} 中进行表达式计算。
  3. 格式化输出:可以使用 f-string 来进行数值、日期等的格式化输出。

优势
简洁性:比传统的 % 格式化或 .format() 更直观简洁。
高效性f-string 的性能比其他格式化方法好,尤其是在处理大量数据时。

3.3 f-string 示例代码

# 定义一些变量用于演示
name = "Alice"  # 姓名
age = 30  # 年龄
height = 1.75  # 身高

# 简单变量嵌入
greeting = f"Hello, my name is {name} and I am {age} years old."
print(greeting)  # Hello, my name is Alice and I am 30 years old.
print("--------------------------------------------------------------------------------------------------------------")

# 表达式计算
area = f"The area of a circle with radius {height} is {3.14 * height ** 2:.2f}."
print(area)  # The area of a circle with radius 1.75 is 9.62.
print("--------------------------------------------------------------------------------------------------------------")

# 使用字典中的值
person = {'name': 'Bob', 'age': 25}
info = f"{person['name']} is {person['age']} years old."
print(info)  # Bob is 25 years old.
print("--------------------------------------------------------------------------------------------------------------")

# 日期格式化
from datetime import datetime

now = datetime.now()
formatted_date = f"Today's date is {now:%Y-%m-%d %H:%M:%S}."
print(formatted_date)  # Today's date is 2025-01-07 14:30:45.
print("--------------------------------------------------------------------------------------------------------------")

总结

特性%格式化str.format()f-string(f 函数)
简洁性较简洁,但不直观相对冗长,尤其是格式较复杂时最简洁,直观易读
灵活性较低,仅支持位置传参高,支持位置和关键字传参高,支持表达式及计算
性能较差比f-string 差,尤其是频繁格式化时最优,特别是频繁格式化时
可读性较差,易出错较好,尤其是复杂格式化时极佳,简洁明了,易于维护
支持表达式不支持支持支持
Python版本支持所有版本所有版本Python3.6及以上
使用场景简单格式化需求,兼容旧版本多变量格式化,关键字传参时高效、简洁的格式化需求

结论:

  • % 格式化:适用于简单格式化,尤其是兼容旧代码时使用。
  • str.format():适用于复杂格式化,尤其需要位置或关键字传递参数时。
  • f-string:推荐用于 Python 3.6 及以上版本,尤其在需要高效、简洁的字符串格式化时使用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值