【Python】*args和**kwargs

server/2024/12/24 0:16:05/

【Python】*args和**kwargs

  • 一、*args: 接收不定数量的位置参数
    • 示例1:简单的加法计算器
    • 示例2:转发参数给另一个函数
  • 二、**kwargs: 接收不定数量的关键字参数
    • 示例3:创建用户配置文件
    • 示例4:合并多个字典
  • 三、组合使用*args和**kwargs
    • 示例5:构建RESTful API请求
  • 四、结论
  • 五、相关链接

一、*args: 接收不定数量的位置参数

在Python中,函数定义时可以通过*args接收任意数量的位置参数。
这里的星号(*)告诉解释器将所有额外的位置参数打包成一个元组传递给函数。
这使得函数可以处理比预期更多的输入,而不必提前确定参数的数量。

示例1:简单的加法计算器

python">def add_numbers(*args):"""计算传入的所有数字之和"""return sum(args)print(add_numbers(1, 2, 3))        # 输出: 6
print(add_numbers(10, 20, 30, 40)) # 输出: 100

在这个例子中,add_numbers函数能够接受任意数量的整数作为参数,并返回它们的总和。
这里的关键点在于*args允许我们不必为每个可能的参数都定义一个变量名,从而使函数更加通用。

示例2:转发参数给另一个函数

有时候你可能会有一个函数A需要调用另一个函数B,并且希望把所有接收到的参数直接传递给B
这时就可以使用*args

python">def wrapper_function(*args):print("Calling the wrapped function with:", args)result = wrapped_function(*args)  # 解包参数传递给wrapped_functionprint("Result from wrapped function:", result)return resultdef wrapped_function(*args):print("Inside wrapped_function with arguments:", args)return sum(args)wrapper_function(1, 2, 3)

这段代码展示了如何通过*args将一组未知长度的位置参数从一个函数传递到另一个函数中。
注意,在调用wrapped_function时,我们使用了*args来解包参数列表,确保每个元素都被当作单独的参数传递过去。

二、**kwargs: 接收不定数量的关键字参数

*args不同,**kwargs用于接收关键字参数,并将它们存储在一个字典里。
这意味着你可以通过键值对的形式向函数传递参数,而不仅仅是按照位置顺序。

示例3:创建用户配置文件

假设我们要创建一个函数来生成用户的个人信息卡片,该卡片可以根据提供的信息动态调整内容:

python">def create_user_profile(**kwargs):"""根据提供的信息创建用户资料"""profile = {}for key, value in kwargs.items():profile[key] = valuereturn profileuser_info = create_user_profile(name="Alice", age=30, city="Beijing")
print(user_info)  # 输出: {'name': 'Alice', 'age': 30, 'city': 'Beijing'}

这里,create_user_profile函数接收了多个关键字参数,并将它们保存到了名为profile的字典中。
这种方式非常适合处理那些具有可选字段的数据结构,如用户配置文件或API请求参数等。

示例4:合并多个字典

如果我们想要合并两个或更多个字典,也可以借助**kwargs来简化操作:

python">def merge_dicts(dict1, **kwargs):"""将多个字典合并为一个新的字典"""merged = dict1.copy()merged.update(kwargs)return mergeddict_a = {"a": 1, "b": 2}
dict_b = {"c": 3, "d": 4}merged_dict = merge_dicts(dict_a, **dict_b)
print(merged_dict)  # 输出: {'a': 1, 'b': 2, 'c': 3, 'd': 4}

此例中,merge_dicts函数首先复制了第一个字典的内容,然后使用update()方法添加了来自其他字典的所有键值对。
**kwargs在这里起到了关键作用,因为它允许我们将第二个字典的内容作为关键字参数传递给函数。

三、组合使用*args和**kwargs

当同时需要支持位置参数和关键字参数时,可以在同一个函数签名中同时包含*args**kwargs
不过要注意的是,*args总是应该出现在**kwargs之前,因为位置参数总是优先于关键字参数进行解析。

示例5:构建RESTful API请求

考虑一个模拟发送HTTP GET请求的函数,它既可以接收查询字符串形式的参数(位置参数),也可以接收表单数据或JSON负载(关键字参数):

python">import requestsdef make_api_request(url, *query_params, **payload):"""构建并发送API请求"""response = requests.get(url, params=query_params, json=payload)return response.json()response_data = make_api_request("https://api.example.com/data",("page", 1),("limit", 10),page_size=50,sort_by="date"
)
print(response_data)

在这个例子中,make_api_request函数既能处理URL后面的查询参数(如分页信息),也能处理POST/PUT请求体中的数据(如果有的话)。
这种灵活性对于构建复杂的Web服务接口非常有用。

四、结论

通过对*args**kwargs的理解,我们可以写出更加健壮、易于维护的Python代码。
这两个特性不仅提高了函数的复用性和适应性,还减少了硬编码参数列表带来的限制。
然而,正如前面提到的那样,过度依赖这些特性可能导致代码难以理解和调试。
因此,在设计API或公共接口时,应当权衡是否真的需要如此高的灵活性,以及这样做是否会牺牲代码的清晰度。

最后,值得注意的是,虽然**kwargs是标准做法,但在某些情况下你可能会看到有人使用**args。
实际上,**args并不是官方推荐的写法,它会引发混淆,因为它违背了约定俗成的命名规范。
始终建议使用**kwargs来表示关键字参数的收集。

五、相关链接

参考文章:

argparse — 用于命令行选项、参数和子命令的解析器

相关文章:

【Python】回调
【Python】argparse模块
【Python】request函数
【Python】yield函数
【Python】Uvicorn服务器
【Python】SSE(Server-Sent Events)
【Python】pydantic库
【Python】pip用法
【Python】Starlette框架
【Python】pip用法


http://www.ppmy.cn/server/152618.html

相关文章

Type-C厂家的环保测试:保障绿色科技的未来

随着科技的飞速发展,USB Type-C接口逐渐成为各种电子产品中标配的连接标准。由于其高效能、便捷性以及广泛的兼容性,Type-C接口的应用已经涵盖了智能手机、笔记本电脑、平板、电视等多个领域。然而,在全球对环境保护日益关注的背景下&#xf…

vtie项目中使用到了TailwindCSS,如何打包成一个单独的CSS文件(优化、压缩)

在不依赖 Vite 或其他构建工具的情况下,使用 TailwindCSS CLI 快速生成独立的 CSS 文件是一种简单高效的方法,适合需要纯样式文件的场景。 这个项目中,使用到了tailwindCss, 需要把里面的样式打包出来,给其他项目用。 使用命令生…

子域提取工具,子域名收集神器,支持多种数据源和枚举选项,域名发现工具,可以为任何目标枚举海量的有效子域名,安全侦察工具,利用证书透明原则监控部署的新子域

子域提取工具,子域名收集神器,支持多种数据源和枚举选项,域名发现工具,可以为任何目标枚举海量的有效子域名,安全侦察工具,利用证书透明原则监控部署的新子域。 需要对目标域名的子域进行深入分析&#xff…

基于asp.net游乐园管理系统设计与实现

博主介绍:专注于Java(springboot ssm 等开发框架) vue .net php python(flask Django) 小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设,从业十五余年开发设计教学工作 ☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不然下次找…

用JAVA做了一个登录窗体练习

目 录 说明运行后的效果代码 说明 做了一个登录窗体作为练习,分享给大家,其中涉及到窗体、图板、随机数等内容,为了方便和我一样的小白可以看的比较明白,所以尽量详细的标注了注释,希望能帮到同样在学习路上的朋友 运…

vue下拉加载页面切换回到当前滚动位置

当项目是下拉分页加载数据时,当离开页面再次回到当前页面时,数据会从第一页重新加载,这就会造成不好的体验。所以解决办法就是在离开当前页面时记录当前滚动的位置,然后再下次回到当前页面时,跳转到当前记录的位置。触…

【Python使用】嘿马头条项目从到完整开发教程第9篇:缓存,1 缓存穿透【附代码文档】

本教程的知识点为:简介 1. 内容 2. 目标 产品效果 ToutiaoWeb虚拟机使用说明 数据库 理解ORM 作用 思考: 使用ORM的方式选择 数据库 SQLAlchemy操作 1 新增 2 查询 all() 数据库 分布式ID 1 方案选择 2 头条 使用雪花算法 (代码 toutiao-backend/common/…

HTMLCSS:这个动态删除按钮打几分?

这段HTML和CSS代码创建了一个可交互的按钮&#xff0c;该按钮在鼠标悬停时会展开显示一个删除图标和文字标签 演示效果 HTML&CSS <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-U…