百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

如何使用 Python 的 f-string 进行字符串格式化

off999 2025-06-08 23:22 20 浏览 0 评论

Python 中的字符串格式化曾经有点麻烦。必须在 % 运算符、str.format() 或字符串连接的组合之间进行选择,才能将变量注入字符串中。幸运的是,Python 3.6 引入了 f-strings(格式化字符串文字),这是一种使代码更简洁、更具可读性和更高效的强大方法。

什么是 f 字符串?

f-string 是前缀为字母 f 的字符串文本,允许在大括号 {} 内包含表达式,这些表达式在运行时进行计算。这使得包含变量值、执行计算甚至调用函数变得容易 - 所有这些都直接在字符串中完成。

下面是一个基本示例:

name = "Alice"
age = 30
message = f"My name is {name} and I am {age} years old."
print(message)

输出:

My name is Alice and I am 30 years old.

f 字符串的美妙之处在于它们的简单性:您只需在开始引号前加上一个 f,然后使用 {} 将值直接插入到字符串中。

f 字符串的优点

1. 可读性

与旧的格式设置方法相比,F 字符串更具可读性,因此很容易看到每个变量或表达式的去向。

2. 简洁

F 字符串消除了对 str.format() 等详细方法调用的需要。您的字符串更简洁,代码更短。

3. 灵活性

可以在 {} 中嵌入任何有效的 Python 表达式,包括算术运算或函数调用。

4. 类型提示集成

使用类型提示时,f-strings 可以帮助确保变量的格式与其预期类型一致:

def greet(user: str) -> str:
    return f"Hello, {user}!"

print(greet("Alice"))

类型提示与 f 字符串相结合,有助于使代码自文档化且可读。

使用 f 字符串的示例

1. 使用 f 字符串格式化变量

假设有一些表示产品的变量:

product = "Laptop"
price = 999.99
formatted = f"The {product} costs ${price:.2f}."
print(formatted)

输出:

The Laptop costs $999.99.

此处,:.2f 指定价格的格式应为小数点后两位 — 非常适合显示货币值。

2. 在 f 字符串中执行计算

您可以直接在 f 字符串中包含计算:

length = 5
width = 3
area_message = f"The area of the rectangle is {length * width} square units."
print(area_message)

输出:

The area of the rectangle is 15 square units.

3. 使用格式说明符

F 字符串支持各种格式说明符来控制输出:

# Right-aligned text with padding
print(f"|{'Hello':>10}|")

# Left-aligned text
print(f"|{'World':<10}|")

# Center-aligned text
print(f"|{'Center':^10}|")

# Formatting numbers
num = 1234.56789
print(f"Number with commas: {num:,.2f}")
print(f"Percentage: {0.756:.1%}")

输出:

|     Hello|
|World     |
| Center   |
Number with commas: 1,234.57
Percentage: 75.6%

4. 使用 f 字符串进行调试

使用 {var=} 语法进行快速调试:

x = 42
print(f"{x=}")

输出:

x=42

高级功能

1. 多行 f 字符串

对于较长的字符串,请使用多行 f 字符串以获得更好的可读性:

name = "Alice"
city = "Wonderland"
message = (
    f"Hello, {name}!\n"
    f"Welcome to {city}. We hope you enjoy your stay."
)
print(message)

2. 处理特殊字符

如果你需要在 f 字符串中包含大括号 {},只需将它们加倍即可:

result = f"To include curly braces, use double braces: {{ and }}."
print(result)

输出:

To include curly braces, use double braces: { and }.

与模板字符串的比较

虽然 f-strings 通常更快、可读性更强,但 string 模块中的 Python 模板字符串在处理不受信任的 input 时提供了更好的安全性。

from string import Template

user_input = "Alice"
template = Template("Hello, $name!")
message = template.substitute(name=user_input)
print(message)

模板字符串更安全,因为它们只允许变量替换,不支持任意表达式。在处理用户生成的内容以防止注入攻击时,这可能是一个显著的优势。

安全注意事项

F 字符串允许任意表达式,如果您直接合并用户输入,这可能会有风险:

user_input = "__import__('os').system('ls')"
# Dangerous! Avoid using f-strings with untrusted input:
# print(f"User input: {user_input}")

相反,在将用户输入包含在 f 字符串中之前,请使用 Template strings 或对其进行清理,以避免潜在的安全漏洞。

性能比较

f 弦的主要优点之一是它们的性能。让我们将 f 字符串与 % 运算符、str.format()模板字符串进行比较:

import timeit

name = "Alice"
age = 30

f_string_time = timeit.timeit("f'{name} is {age} years old'", globals=globals(), number=1000000)
format_time = timeit.timeit("'{} is {} years old'.format(name, age)", globals=globals(), number=1000000)
percent_time = timeit.timeit("'%s is %d years old' % (name, age)", globals=globals(), number=1000000)
template_time = timeit.timeit("Template('$name is $age years old').substitute(name=name, age=age)", 
                              globals=globals(), number=1000000)

print(f"f-string: {f_string_time:.6f}s, str.format(): {format_time:.6f}s, %-formatting: {percent_time:.6f}s, Template: {template_time:.6f}s")

典型输出:

f-string: 0.085123s, str.format(): 0.121456s, %-formatting: 0.130567s, Template: 0.155789s

结论:f 字符串是最快的,但如果安全是一个问题(例如,处理用户输入),请考虑使用模板字符串。

要避免的陷阱

1. 仅限 Python 3.6+

F 字符串仅在 Python 3.6 及更高版本中可用。如果您使用的是旧版本,则需要使用其他格式设置方法。

2. 保持表达式简单

避免在 {} 中使用过于复杂的表达式以提高可读性:

# Instead of this:
formatted = f"The result is {((10 ** 2 + 5) / 3):.2f}"

# Do this:
result = (10 ** 2 + 5) / 3
formatted = f"The result is {result:.2f}"

3. 谨慎对待用户输入

切勿直接将 f 字符串与不受信任的输入一起使用。使用 Template strings 以获得更安全的方法。

结论

F 字符串提供了一种现代、可读且简洁的方式来在 Python 中格式化字符串。它们功能强大、灵活且性能卓越,是大多数使用案例的理想选择。但是,对于涉及用户输入的方案,请考虑使用 Template strings 以避免安全问题。

相关推荐

阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?

TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...

高流量大并发Linux TCP性能调优_linux 高并发网络编程

其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...

性能测试100集(12)性能指标资源使用率

在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...

Linux 服务器常见的性能调优_linux高性能服务端编程

一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...

Nginx性能优化实战:手把手教你提升10倍性能!

关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...

高并发场景下,Spring Cloud Gateway如何抗住百万QPS?

关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...

Kubernetes 高并发处理实战(可落地案例 + 源码)

目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...

高并发场景下,Nginx如何扛住千万级请求?

Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...

Spring Boot+Vue全栈开发实战,中文版高清PDF资源

SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...

Docker-基础操作_docker基础实战教程二

一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...

你有空吗?跟我一起搭个服务器好不好?

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...

部署你自己的 SaaS_saas如何部署

部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...

Docker Compose_dockercompose安装

DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...

京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统

前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...

Kubernetes (k8s) 入门学习指南_k8s kubeproxy

Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...

取消回复欢迎 发表评论: