0

0

Python字符串格式化怎么用_fstring与format全面解析【教程】

舞姬之光

舞姬之光

发布时间:2025-12-31 20:18:08

|

340人浏览过

|

来源于php中文网

原创

f-string是python 3.6+首选,str.format()仅用于动态字段名、参数复用或外部模板;%格式化已不推荐。

python字符串格式化怎么用_fstring与format全面解析【教程】

Python 字符串格式化不用学三套语法——f-string 是 3.6+ 的首选,str.format() 仅在需要动态字段名或兼容旧版本时才用,% 格式化已不推荐。

什么时候必须用 str.format() 而不能用 f-string

f-string 在表达式里不能直接展开变量名以外的动态字段(比如字典键、属性名需提前确定),而 str.format() 支持运行时解析字段路径。

  • 要根据变量值动态取字典字段:
    data = {'name': 'Alice', 'age': 30}
    key = 'age'
    # ✅ 可行:format 支持 {0[key]} 这类动态索引
    s = "{0[{1}]}".format(data, key)  # → '30'
    <h1>❌ 报错:f-string 中 {data[key]} 是合法的,但 {data[{key}]} 会语法错误</h1><h1>正确写法只能是 f"{data[key]}",前提是 key 已定义且为合法表达式
  • 需要复用同一参数多次,且位置不连续:
    "{0} 和 {0} 都喜欢 {1}".format("Tom", "Python")
  • 模板来自外部(如配置文件、数据库),无法预编译成 f-string

f-string 的真实限制和常见误用

f-string 表达式在运行时求值,但不允许赋值、语句、反斜杠续行,也不能嵌套另一个 f-string

  • 以下写法全部非法:
    f"{x = }"     # Python 3.8+ 才支持调试语法(带 =),3.7 及更早报错
    f"{x += 1}"   # 语法错误:不能含赋值语句
    f"hello\world" # 反斜杠不能跨行,除非用括号包裹整个 f-string
    f"{f'{x}'}"    # 嵌套 f-string 不被允许
  • 函数调用没问题,但要注意副作用:
    def log(x): print(f"logging: {x}"); return x
    f"result: {log(42)}"  # 会先打印 logging: 42,再拼字符串
  • 性能上,f-stringformat() 快约 2–3 倍(尤其多字段场景),因为不涉及方法查找与解析逻辑

format() 的格式说明符怎么对应 f-string 写法

两者格式说明符语法一致,都遵循 {field_name:format_spec} 结构,只是填充方式不同。

ChatPs
ChatPs

一款基于Photoshop的AI插件

下载

立即学习Python免费学习笔记(深入)”;

  • 对齐与宽度:
    f"{x:<10}"      # 左对齐,总宽 10
    "{:<10}".format(x)
    <p>f"{x:05d}"       # 补零五位整数
    "{:05d}".format(x)
  • 浮点精度控制完全相同:
    f"{pi:.3f}"      # 3.142(假设 pi=3.14159)
    "{:.3f}".format(pi)
  • 千位分隔符也一致:
    f"{n:,}"         # 如 1234567 → '1,234,567'
    "{:,}".format(n)
  • 唯一区别:f-string 中字段名可以是任意表达式,format() 中字段名只能是位置索引、关键字或简单属性访问(如 {obj.name}

兼容性与迁移建议

如果你的项目最低要求 Python ≥ 3.6,就无条件优先用 f-string;若需支持 3.5 或更早,str.format() 是唯一现代选择(% 格式化不支持命名参数、类型检查弱、易出错)。

  • 已有 format() 代码迁移到 f-string 时注意:
    # 原写法
    s = "{name} is {age} years old".format(name="Bob", age=25)
    <h1>直接等价迁移(变量需已存在)</h1><p>name, age = "Bob", 25
    s = f"{name} is {age} years old"
  • 含复杂表达式的 format() 模板(如 {user.get('profile', {}).get('city', 'N/A')})可直接塞进 f-string:
    f"{user.get('profile', {}).get('city', 'N/A')}"
  • 别为了“统一风格”强行把所有 format() 改成 f-string —— 如果模板本身是字符串常量、用于日志格式化或框架接口(如 logging.Formatter),保留 format() 更清晰可控

真正容易被忽略的是:f-string 的表达式在编译期就确定作用域,它捕获的是当前作用域的变量快照,不是闭包延迟求值;而 format() 字符串本身不执行任何逻辑,安全得多。混合使用时,别默认它们行为对等。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

970

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

867

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

458

2024.06.27

字符串常量的表示方法
字符串常量的表示方法

字符串常量的表示方法:1、使用引号;2、转义字符;3、多行字符串;4、原始字符串;5、字符串连接;6、字符串字面量和对象;7、编码问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

143

2023.12.26

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

718

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号