f-string是python字符串拼接的首选方式,编译期完成格式化、运行时开销小;大量片段拼接应使用str.join();避免在循环中用+=拼接长字符串。

字符串拼接方式直接影响执行效率
Python中看似简单的字符串拼接,不同写法在大数据量或高频调用场景下性能差异显著。核心原因在于字符串的不可变性——每次拼接都可能触发新对象创建与内存复制。选择合适方式,能避免不必要的开销。
f-string(Python 3.6+)通常是首选
f-string 在编译期完成格式化,运行时开销极小,语法简洁且可读性强。它比 % 格式化和 .format() 更快,也比反复 += 拼接更高效(尤其在循环中)。
- 适用场景:单次或少量变量插值,如日志、提示信息
- 示例:f"用户 {name} 登录成功,耗时 {elapsed:.2f}s"
- 注意:避免在 f-string 中嵌入复杂表达式或函数调用,否则可能抵消性能优势
大量片段拼接优先用 str.join()
当需要合并多个字符串(尤其是列表或生成器中的大量元素)时,''.join(list_of_strings) 是最优解。它只分配一次目标内存,一次性拷贝所有内容,时间复杂度为 O(n)。
- 对比:+= 在循环中是 O(n²),因每次都要新建字符串并复制前序内容
- 正确用法:result = ''.join(['Hello', ' ', 'world', '!', '\n'])
- 进阶技巧:配合生成器表达式节省内存,如 ''.join(str(x) for x in range(1000))
避免在循环中使用 += 拼接长字符串
虽然代码直观,但底层会频繁申请新内存、复制旧内容,性能随数据量增长急剧下降。即使 Python 的 CPython 实现对短字符串有小优化(如“空闲列表”复用),也不建议依赖。
立即学习“Python免费学习笔记(深入)”;
- 反例:s = ''; for item in data: s += str(item)
- 替代方案:先收集到列表,再用 join;或直接用生成器 + join
- 调试提示:可用 timeit 快速验证,10万次拼接,join 通常比 += 快 10–100 倍
其他情况按需选择
% 格式化和 .format() 已基本被 f-string 取代,仅在需兼容旧版本或动态模板(如从配置加载格式串)时使用。模板引擎(如 Jinja2)适合复杂文本生成,但引入额外依赖,不适用于简单拼接。
- 字符串常量拼接(如 'a' 'b' 'c')由解释器自动优化为单个字面量,无需担心
- IO 类操作(如写文件)建议用 print(..., file=f) 或 f.write() 分批处理,而非先拼大字符串再写入











