Python3: args and kwargs详解

*args and **kwargs

并不是必须写成这样,只有变量前面的(*)才是必须的

主要用于函数定义,可以将不定数量的参数传递给一个函数

# 不定的意思是:预先并不知道,函数使用者会传递多少个参数
# *arg 是用来发送一个非键值对的可变数量的参数列表给一个函数
def test_var_args(f_arg, *args):
    print("first normal arg:", f_arg)
    for arg in args:
        print("another arg through *args:", arg)
test_var_args('google','python','pytorch','tensorflow')
first normal arg: google
another arg through *args: python
another arg through *args: pytorch
another arg through *args: tensorflow
# **kwargs 允许将不定长度的键值对,作为参数传递给一个函数。比如处理带名字的参数
def greet_me(**kwargs):
    for key, value in kwargs.items():
        print("{0} == {1}".format(key, value))
greet_me(name="python")
name == python
# 使用*args 和 **kwargs来调用函数
def test_args_kwargs(arg1, arg2, arg3):
    print("arg1:", arg1)
    print("arg2:", arg2)
    print("arg3:", arg3)
args = ("python", 3, 5)
test_args_kwargs(*args)
arg1: python
arg2: 3
arg3: 5
kwargs = {"arg1": 3, "arg2": "python", "arg3": 5}
test_args_kwargs(**kwargs)
arg1: 3
arg2: python
arg3: 5

注意:标准参数与* args 和 ** kwargs 在使用时的顺序是:

some_func(fargs, * args, ** kwargs)

什么时候使用?

最常见的就是在写函数装饰器的时候

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZPILOTE

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值