0

0

Python 字符串 format 中动态键名的正确用法

碧海醫心

碧海醫心

发布时间:2026-02-16 23:21:00

|

933人浏览过

|

来源于php中文网

原创

Python 字符串 format 中动态键名的正确用法

本文详解如何在 Python 的 str.format() 中安全、灵活地使用变量作为占位符键名,避免 KeyError,并提供基于 **dict 解包和 __dict__ 的两种实用方案。

本文详解如何在 python 的 `str.format()` 中安全、灵活地使用变量作为占位符键名,避免 keyerror,并提供基于 `**dict` 解包和 `__dict__` 的两种实用方案。

在使用 str.format() 进行模板字符串填充时,若占位符为 {dntier},则 format() 会严格查找名为 dntier 的关键字参数;而直接传入 format(text_variable=value) 并不会自动将变量名 text_variable 替换为它所存储的字符串(如 'dntier')——这是常见误区。Python 不会对关键字参数名做运行时求值,因此 text_string.format(text_variable=replacement) 实际尝试替换的是 {text_variable},而非 {dntier},从而触发 KeyError: 'dntier'。

✅ 正确解法一:动态构建字典并解包(推荐)

利用字典解包语法 **{key: value},可将运行时获得的属性名与值构造成合法的关键字参数:

import re

class Test:
    def __init__(self, mdtier, rxtier, dntier, vstier):
        self.mdtier = mdtier  # 注意:原代码中逗号导致元组赋值,已修正
        self.rxtier = rxtier
        self.dntier = dntier
        self.vstier = vstier

rec = Test('You Only', 'You Only', 'You + Family', 'You + Spouse')
text_string = 'Dental coverage for {dntier}.'

# 提取占位符名(如 'dntier')
match = re.search(r'\{([^}]+)\}', text_string)
if match:
    attr_name = match.group(1)
    try:
        replacement = getattr(rec, attr_name)  # 直接获取属性值(无需 [0])
        new_text_string = text_string.format(**{attr_name: replacement})
        print(new_text_string)  # 输出:Dental coverage for You + Family.
    except AttributeError:
        print(f"Attribute '{attr_name}' not found on object.")
else:
    new_text_string = text_string

⚠️ 注意事项:

  • 原示例中 self.dntier = dntier, 的末尾逗号会导致属性被赋值为单元素元组(如 ('You + Family',)),务必移除逗号以确保获取真实字符串值;
  • getattr() 可能抛出 AttributeError,建议用 try/except 包裹或配合 hasattr() 预检;
  • 正则表达式 r'\{([^}]+)\}' 比 \{(.+?)\} 更健壮,避免匹配嵌套大括号(虽本例无此需求,但属良好实践)。

✅ 正确解法二:批量注入对象所有属性(适用于全量替换)

若模板中可能包含多个占位符(如 {mdtier}、{vstier}),且均对应对象属性,可直接使用 obj.__dict__:

知料万语
知料万语

知料万语—AI论文写作,AI论文助手

下载

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

text_string = 'Medical: {mdtier}, Vision: {vstier}, Dental: {dntier}.'
new_text_string = text_string.format(**rec.__dict__)
print(new_text_string)
# 输出:Medical: You Only, Vision: You + Spouse, Dental: You + Family.

__dict__ 返回对象实例的属性字典(不含方法和继承属性),天然适配 ** 解包,简洁高效。但需注意:

  • 仅适用于所有占位符均有对应实例属性的场景;
  • 若存在未定义属性或私有属性(如 _internal),可能导致意外行为,生产环境建议先过滤字典键。

总结

方案 适用场景 安全性 灵活性
format(**{key: value}) 单个/部分占位符,键名动态生成 ★★★★☆(需手动校验属性存在) ★★★★★(完全可控)
format(**obj.__dict__) 多占位符且全部映射到实例属性 ★★★☆☆(依赖属性完整性) ★★★★☆(简洁但粒度粗)

核心原则始终是:str.format() 的关键字参数名必须与模板中占位符名称字面一致;动态键名必须通过字典解包实现,不可直接传递变量名本身。 掌握这一机制,即可稳健支撑配置化文本渲染、邮件模板、日志消息等典型应用场景。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

521

2023.06.20

正则表达式不包含
正则表达式不包含

正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

254

2023.07.05

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

757

2023.07.05

java正则表达式匹配字符串
java正则表达式匹配字符串

在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

219

2023.08.11

正则表达式空格
正则表达式空格

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。本专题为大家提供正则表达式相关的文章、下载、课程内容,供大家免费下载体验。

354

2023.08.31

Python爬虫获取数据的方法
Python爬虫获取数据的方法

Python爬虫可以通过请求库发送HTTP请求、解析库解析HTML、正则表达式提取数据,或使用数据抓取框架来获取数据。更多关于Python爬虫相关知识。详情阅读本专题下面的文章。php中文网欢迎大家前来学习。

293

2023.11.13

正则表达式空格如何表示
正则表达式空格如何表示

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。想了解更多正则表达式空格怎么表示的内容,可以访问下面的文章。

244

2023.11.17

正则表达式中如何匹配数字
正则表达式中如何匹配数字

正则表达式中可以通过匹配单个数字、匹配多个数字、匹配固定长度的数字、匹配整数和小数、匹配负数和匹配科学计数法表示的数字的方法匹配数字。更多关于正则表达式的相关知识详情请看本专题下面的文章。php中文网欢迎大家前来学习。

539

2023.12.06

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

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

精品课程

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

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

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

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