0

0

Python *args 和 **kwargs 的真实用途

冷炫風刃

冷炫風刃

发布时间:2026-01-31 18:21:08

|

727人浏览过

|

来源于php中文网

原创

必须用args和*kwargs的场景是函数签名无法预知参数个数或类型时,如写装饰器、封装API、通用回调、可扩展初始化;二者须按序出现且不可颠倒。

python *args 和 **kwargs 的真实用途

什么时候必须用 *args**kwargs

不是为了“看起来高级”,而是当函数签名无法提前确定参数个数或类型时,才真正需要它们。典型场景包括:写装饰器、封装第三方 API 调用、实现通用回调函数、构建可扩展的类初始化逻辑。

比如你写一个日志装饰器,要兼容所有被装饰函数的参数形式——它可能有 2 个位置参数,也可能有 5 个关键字参数,甚至混合使用。这时候硬编码 def wrapper(a, b, c=None) 必然失败,而 *args**kwargs 是唯一能兜住所有情况的方式。

  • *args 接收任意数量的位置参数,打包成 tuple;**kwargs 接收任意数量的关键字参数,打包成 dict
  • 二者必须按顺序出现:def func(a, b, *args, **kwargs),不能颠倒,也不能插在必选参数中间
  • 如果只传了关键字参数但函数没声明 **kwargs,会直接报 TypeError: func() got an unexpected keyword argument

*args 不是万能的“多参数兜底”,它会吃掉本该报错的调用

假设你定义 def send_email(to, subject, *args),本意是让 tosubject 强制存在,其余可选。但调用 send_email("a@b.com") 不会报错——subject 会被当成第一个 *args 元素,to 反而成了 subject,逻辑全乱。

更安全的做法是用仅限关键字参数(keyword-only)来守住关键字段:

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

def send_email(*, to, subject, body="", cc=None):
    ...

这样 send_email("a@b.com", "hi") 就会立刻报错,强制调用方显式命名。

Sesame AI
Sesame AI

一款开创性的语音AI伴侣,具备先进的自然对话能力和独特个性。

下载
  • *args 适合“追加可选内容”,不适合“模糊必填项”
  • 如果函数逻辑依赖某些参数一定存在,别靠 *args 吞掉,用命名参数 + * 分隔符约束
  • 调试时打印 argskwargs 内容,常发现传参顺序错位——这是最隐蔽的 bug 来源之一

**kwargs 常见误用:盲目透传导致配置项失效

很多人写封装函数时习惯这么干:

def safe_request(url, **kwargs):
    return requests.get(url, **kwargs)

表面看没问题,但 requests.get() 本身接受 timeoutheadersverify 等几十个参数,而你的 safe_request 没做任何校验或默认值处理。结果可能是:用户传了 timeout=0.1 却没意识到这会让请求极易失败;或传了 verify=False 绕过证书验证却没留日志。

  • 透传 **kwargs 前,至少应过滤、记录或转换关键参数(如把 retries 映射到内部 Session 配置)
  • 不要让 **kwargs 成为“逃避设计”的借口——哪些参数该暴露?哪些该封装?得想清楚
  • 如果函数只接受特定几个关键字参数,直接列出来比用 **kwargs 更清晰、更易维护

组合使用时容易忽略的细节:解包顺序和覆盖逻辑

当你同时解包多个参数来源时,顺序决定覆盖结果。例如:

defaults = {"timeout": 5, "verify": True}
user_opts = {"timeout": 0.5}
requests.get(url, **defaults, **user_opts)  # timeout=0.5 生效
requests.get(url, **user_opts, **defaults)  # timeout=5 生效(错误!)

这种写法在动态构造请求参数时很常见,但一旦顺序写反,关键配置就被静默覆盖。

  • Python 3.9+ 支持 | 合并字典:final_kwargs = defaults | user_opts,更明确、不可逆
  • dict(**defaults, **user_opts) 也行,但要注意后者字段会覆盖前者
  • 如果涉及嵌套结构(如 headers 合并),**kwargs 无法自动 merge,得手动处理

真正难的从来不是语法,而是搞清谁该控制什么参数、谁该负责校验、谁该承担默认行为——*args**kwargs 只是工具,不是设计决策的替代品。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

316

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

752

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

95

2025.08.19

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

52

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

40

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

50

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

11

2026.01.31

漫画防走失登陆入口大全
漫画防走失登陆入口大全

2026最新漫画防走失登录入口合集,汇总多个稳定可用网址,助你畅享高清无广告漫画阅读体验。阅读专题下面的文章了解更多详细内容。

13

2026.01.31

php多线程怎么实现
php多线程怎么实现

PHP本身不支持原生多线程,但可通过扩展如pthreads、Swoole或结合多进程、协程等方式实现并发处理。阅读专题下面的文章了解更多详细内容。

1

2026.01.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新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号