python中*args和**kwargs详解

*args和**kwargs在Python函数定义中用于处理不定数量的参数。*args接收非键值对参数,而**kwargs接收键值对参数。本文通过实例解释了如何使用这两个特性,并讨论了它们在函数装饰器和猴子补丁中的应用。

*args 和 **kwargs主要用于函数定义,其可以将不定数量的参数传递给一个函数。

不定数量指的是预先不知道函数使用者会传递多少个参数给你,所有在这个场景下使用这两个关键字。

*args是用来传递一个非键值对的可变数量的参数列表给函数。

例子:

def test_var_args(f_arg, *argv):
    print("first normal arg:", f_arg)
    for arg in argv:
        print("another arg through *argv:", arg)

if __name__ == '__main__':
    test_var_args('yasoob', 'python', 'eggs', 'test')

输出:

first normal arg: yasoob
another arg through *argv: python
another arg through *argv: eggs
another arg through *argv: test

**kwargs允许将不定长度的键值对,作为参数传递给函数。如果需要在一个函数中处理带名字的参数,应该使用**kwargs.

def greet_me(**kwargs):
    for key, value in kwargs.items():
        print("{0} == {1}".format(key, value))

>>> greet_me(name="yasoob")
name == yasoob

标准参数与*args、**kwargs在使用时的顺序

some_func(fargs, *args, **kwargs)

什么时候使用它们?

最常见的用例是在写函数装饰器的时候(会在另一章里讨论)。

此外它也可以用来做猴子补丁(monkey patching)。猴子补丁的意思是在程序运行时(runtime)修改某些代码。 打个比方,你有一个类,里面有个叫get_info的函数会调用一个API并返回相应的数据。如果我们想测试它,可以把API调用替换成一些测试数据。例如:

import someclass

def get_info(self, *args):
    return "Test data"

someclass.get_info = get_info

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值