0

0

Python 字符串拼接的多种方式与性能对比

冰川箭仙

冰川箭仙

发布时间:2026-01-30 16:25:26

|

592人浏览过

|

来源于php中文网

原创

Python字符串不可变,+拼接需频繁新建对象,n次拼接产生n-1次拷贝,时间复杂度近O(n²);循环中+=性能断崖下跌,应改用list.append()+"".join()。

python 字符串拼接的多种方式与性能对比

+ 拼接字符串时,为什么越拼越慢?

因为 Python 字符串不可变,每次 + 都会新建对象。拼接 n 个字符串,实际产生 n-1 次中间字符串拷贝,时间复杂度接近 O(n²)

常见错误场景:在循环里反复 += 累加日志或 HTML 片段——小数据看不出问题,一旦字符串总长超几 KB,性能断崖式下跌。

  • 适合拼接 2–3 个短字符串(如 "Hello" + name + "!"
  • 避免在 for 循环中使用 += 构建长字符串
  • 如果必须动态累积,先存入 list,最后用 "".join()

str.join() 是不是永远最快?

绝大多数情况下是的,尤其当待拼接内容已存在(如列表、元组),str.join() 只需一次内存预分配和单次遍历,时间复杂度 O(n)

但要注意:它要求所有元素都是 str 类型,否则直接报 TypeError: sequence item 0: expected str instance

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

Cutout.Pro
Cutout.Pro

AI驱动的视觉设计平台

下载
  • 拼接大量已知字符串(如日志行、CSV 字段)首选 "\n".join(lines)
  • 含非字符串元素时,先统一转 str" ".join(map(str, data))
  • 单个字符串调用 "".join([s]) 没有意义,反而多一层函数调用开销

f-string 和 format() 在什么场景下更合适?

f-string(Python 3.6+)本质是运行时表达式求值 + 字符串插值,不涉及拼接逻辑,性能接近直接字面量;str.format() 稍慢,但支持命名参数和复用模板。

它们的优势不在“拼接速度”,而在可读性与格式控制——比如带精度、对齐、类型转换的输出。

  • 变量插值优先用 f-string:f"User {uid} logged in at {datetime.now():%H:%M}"
  • 需要复用同一格式多次(如生成多行报表),用 template = "ID: {:04d}, Name: {}" 配合 template.format(id, name)
  • 避免用 f-string 拼接大量动态片段(如循环内生成 HTML 标签),应改用 list.append() + join()

为什么 % 格式化现在不推荐?

% 是 Python 最老的格式化方式,语法紧凑但扩展性差,不支持命名参数嵌套、无法直接处理 None(会抛 TypeError),且和 C 风格耦合过深,易出错。

虽然它在简单场景(如 "%s: %d" % (name, count))仍有可读性,但和 f-string 相比毫无性能优势,还增加维护成本。

  • 新代码一律避开 %,哪怕只是两个变量也用 f-string
  • 遗留代码中遇到 %,不要为了“统一风格”强行改成 format(),优先升级为 f-string
  • logging 模块仍支持 % 占位(如 logger.info("User %s failed %d times", user, n)),这是特例,不触发字符串拼接,可保留
真正影响性能的从来不是“选哪种语法”,而是“是否在错误的抽象层做操作”——比如用字符串拼接代替模板引擎,或把本该批量处理的 IO 拆成上百次 +=。f-string 再快,也救不了在循环里拼 SQL 的设计。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

749

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

328

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

350

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1283

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

361

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

861

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

423

2024.04.29

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

热门下载

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

精品课程

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

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

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

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