【Python】*args和**kwargs
【Python】*args和**kwargs
- 一、*args: 接收不定数量的位置参数
- 示例1:简单的加法计算器
- 示例2:转发参数给另一个函数
- 二、**kwargs: 接收不定数量的关键字参数
- 示例3:创建用户配置文件
- 示例4:合并多个字典
- 三、组合使用*args和**kwargs
- 示例5:构建RESTful API请求
- 四、结论
- 五、相关链接
一、*args: 接收不定数量的位置参数
在Python中,函数定义时可以通过*args接收任意数量的位置参数。
这里的星号(*)告诉解释器将所有额外的位置参数打包成一个元组传递给函数。
这使得函数可以处理比预期更多的输入,而不必提前确定参数的数量。
示例1:简单的加法计算器
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:
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:创建用户配置文件
假设我们要创建一个函数来生成用户的个人信息卡片,该卡片可以根据提供的信息动态调整内容:
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来简化操作:
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负载(关键字参数):
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用法
相关文章:
【Python】*args和**kwargs
【Python】*args和**kwargs 一、*args: 接收不定数量的位置参数示例1:简单的加法计算器示例2:转发参数给另一个函数 二、**kwargs: 接收不定数量的关键字参数示例3:创建用户配置文件示例4:合并多个字典 三、组合使用*args和**kwar…...
使用正则表达式提取PDF文件页数的实现方案
文章目录 背景介绍实现原理代码实现1. 基础函数结构2. 页数提取逻辑3. 使用示例 正则表达式解析优点与局限性优点局限性 错误处理建议性能优化建议最佳实践建议总结参考资源 背景介绍 在Web应用开发中,我们经常需要获取上传PDF文件的页数信息。虽然可以使用pdf.js等第三方库,但…...
Android实现RecyclerView边缘渐变效果
Android实现RecyclerView边缘渐变效果 1.前言: 是指在RecyclerView中实现淡入淡出效果的边缘效果。通过这种效果,可以使RecyclerView的边缘在滚动时逐渐淡出或淡入,以提升用户体验。 2.Recyclerview属性: 2.1、requiresFading…...
springboot443旅游管理系统(论文+源码)_kaic
摘 要 如今社会上各行各业,都喜欢用自己行业的专属软件工作,互联网发展到这个时候,人们已经发现离不开了互联网。新技术的产生,往往能解决一些老技术的弊端问题。因为传统旅游管理系统信息管理难度大,容错率低&#…...
利用git上传项目到GitHub
GitHub是基于git实现的代码托管。git是目前最好用的版本控制系统了,非常受欢迎,比之svn更好。 GitHub可以免费使用,并且快速稳定。 利用GitHub,你可以将项目存档,与其他人分享交流,并让其他开发者帮助你一…...
Rust之抽空学习系列(四)—— 编程通用概念(下)
Rust之抽空学习系列(四)—— 编程通用概念(下) 1、函数 函数用来对功能逻辑进行封装,能够增强复用、提高代码的可读 以下是函数的主要组成部分: 名称参数返回类型函数体 1.1、函数名称 在Rust中&…...
K-Means 聚类:数据挖掘的瑞士军刀
引言 在数据科学领域,聚类算法是一种非常重要的无监督学习方法,它能够帮助我们发现数据中的自然分组或模式。其中,K-Means 聚类算法因其简单高效而成为最常用的聚类算法之一。无论是市场细分、社交网络分析,还是图像分割等领域&a…...
项目练习:若依-前端项目的目录结构介绍
文章目录 一、目录截图二、目录讲解 一、目录截图 二、目录讲解 1、首先,我们可以看到,这个VUE项目,只有一个App.vue,所以,它是一个单页面系统。 这个App.vue是根组件,root组件。 2、public目录 在Vue 3.…...
知网研学 | 知网文献(CAJ+PDF)批量下载
知网文献(CAJPDF)批量下载 一、知网研学安装二、插件及脚本安装三、CAJ批量下载四、脚本下载及PDF批量下载浏览器取消拦截窗口 一、知网研学安装 批量下载知网文件,格式为es6文件,需使用知网研学软件打开,故需先安装该…...
设计模式期末复习
一、设计模式的概念以及分类 二、设计模式的主题和意图 三、面向对象程序设计原则,记住名字,还要理解它的使用场景以及如何用? 四、松耦合、紧耦合、强关联、弱关联、静态复用、动态复用的概念,还有静态委派,动态委…...
CentOS7源码编译安装nginx+php+mysql
1.安装nginx 安装依赖 yum -y install gcc gcc-c wget automake autoconf libtool libxml2-devel libxslt-devel perl-devel perl-ExtUtils-Embed pcre-devel openssl openssl-devel 创建一个不能登录的nginx运行用户 groupadd www-data useradd -s /sbin/nologin -g www-d…...
linux CentOS系统上卸载docker
一、停止Docker服务 首先,需要停止Docker服务。使用systemctl命令来停止Docker服务: bash复制代码sudo systemctl stop docker二、卸载Docker软件包 接下来,使用CentOS的包管理器yum来卸载Docker软件包。根据安装的Docker版本和组件&#…...
css中相对定位的应用场景
元素位置微调 文本与图标组合微调:在网页设计中,经常会有文本和图标的组合,比如一个带有搜索图标的搜索框。可以使用相对定位来微调图标在搜索框内的位置。例如,有以下HTML结构: <input type"text" class…...
Android 获取屏幕物理尺寸
注:编译 sdk 需要使用 30 因为引入了 WindowMetrics、uild.VERSION_CODES.R 新 sdk 才存在的类和属性 某些场景处理 view ,对 view 显示的位置要求比较精确,通常我们使用context.getResources().getDisplayMetrics().widthPixels 获取到的宽、…...
C缺陷与陷阱 — 8 编译与链接
目录 1 程序的编译过程 2 动态链接的优缺点 2.1 动态链接的优点 2.2 动态链接的缺点 2.3 只使用动态链接 3 函数库链接的5个特殊秘密 4 警惕Interpositioning 5 产生链接器报告文件 1 程序的编译过程 程序的编译过程是将源代码转换成计算机可以执行的机器代码的过程。…...
知识分享第三十天-力扣343.(整数拆分)
343 整数拆分 给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化。 返回你可以获得的最大乘积。 示例 1: 输入: 2 输出: 1 解释: 2 1 1, 1 1 1。 示例 2: 输入: 10 输出: 36 解释: 10 3 3 4, 3 3 4 36。 说明: 你可…...
Springboot 整合DL4J 打造智能写作助手(文本生成)
项目准备 环境要求: Java 1.8或以上 Maven 或 Gradle(用于项目管理) Spring Boot框架 DL4J库(DeepLearning4J) 创建 Spring Boot 项目 使用 Spring Initializr 来生成一个新的 Spring Boot 项目。选择合适的依赖,例如…...
SPL06 基于stm32F103 HAL库驱动(软件模拟IIC)
talk is cheap, show you my code SPL06.c #include "SPL06.h"//*************全局变量*************// Factor_List* b_list; //存储过采样率对应的系数KP,KT COEF_ValueStruct Coefficient { 0 }; //存储校准系数…...
【C#】List求并集、交集、差集
值类型List List<int> intList1 new List<int>() { 1, 2, 3 };List<int> intList2 new List<int>() { 3, 4, 5 };var result intList1.Union(intList2);Console.WriteLine($"并 {string.Join(,,result)}");result intList1.Intersect(in…...
YOLOv8目标检测——详细记录使用ONNX Runtime进行推理部署C++/Python实现
概述 在之前博客中有介绍YOLOv8从环境安装到训练的完整过程,本节主要介绍ONNX Runtime的原理以及使用其进行推理加速,使用Python、C两种编程语言来实现。 https://blog.csdn.net/MariLN/article/details/143924548?spm1001.2014.3001.5501 1. ONNX Ru…...
业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...
通过Wrangler CLI在worker中创建数据库和表
官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...
【Linux】C语言执行shell指令
在C语言中执行Shell指令 在C语言中,有几种方法可以执行Shell指令: 1. 使用system()函数 这是最简单的方法,包含在stdlib.h头文件中: #include <stdlib.h>int main() {system("ls -l"); // 执行ls -l命令retu…...
MODBUS TCP转CANopen 技术赋能高效协同作业
在现代工业自动化领域,MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步,这两种通讯协议也正在被逐步融合,形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...
【RockeMQ】第2节|RocketMQ快速实战以及核⼼概念详解(二)
升级Dledger高可用集群 一、主从架构的不足与Dledger的定位 主从架构缺陷 数据备份依赖Slave节点,但无自动故障转移能力,Master宕机后需人工切换,期间消息可能无法读取。Slave仅存储数据,无法主动升级为Master响应请求ÿ…...
项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)
Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败,具体原因是客户端发送了密码认证请求,但Redis服务器未设置密码 1.为Redis设置密码(匹配客户端配置) 步骤: 1).修…...
rnn判断string中第一次出现a的下标
# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...
Selenium常用函数介绍
目录 一,元素定位 1.1 cssSeector 1.2 xpath 二,操作测试对象 三,窗口 3.1 案例 3.2 窗口切换 3.3 窗口大小 3.4 屏幕截图 3.5 关闭窗口 四,弹窗 五,等待 六,导航 七,文件上传 …...
力扣热题100 k个一组反转链表题解
题目: 代码: func reverseKGroup(head *ListNode, k int) *ListNode {cur : headfor i : 0; i < k; i {if cur nil {return head}cur cur.Next}newHead : reverse(head, cur)head.Next reverseKGroup(cur, k)return newHead }func reverse(start, end *ListNode) *ListN…...
