• python 中的 *args 和 **kwargs


    *args的用法

    *args就是就是传递一个可变参数列表给函数实参,这个参数列表的数目未知,甚至长度可以为0。下面这段代码演示了如何使用args

    def test_args(first, *args):
        print('Required argument: ', first)
        print(type(args))
        for v in args:
            print ('Optional argument: ', v)
    
    test_args(1, 2, 3, 4)

    第一个参数是必须要传入的参数,所以使用了第一个形参,而后面三个参数则作为可变参数列表传入了实参,并且是作为元组tuple来使用的。代码的运行结果如下

    Required argument:  1
    <class 'tuple'>
    Optional argument:  2
    Optional argument:  3
    Optional argument:  4
    

    **kwargs

    而**kwargs则是将一个可变的关键字参数的字典传给函数实参,同样参数列表长度可以为0或为其他值。下面这段代码演示了如何使用kwargs

    def test_kwargs(first, *args, **kwargs):
       print('Required argument: ', first)
       print(type(kwargs))
       for v in args:
          print ('Optional argument (args): ', v)
       for k, v in kwargs.items():
          print ('Optional argument %s (kwargs): %s' % (k, v))
    
    test_kwargs(1, 2, 3, 4, k1=5, k2=6)

    正如前面所说的,args类型是一个tuple,而kwargs则是一个字典dict,并且args只能位于kwargs的前面。代码的运行结果如下

    Required argument:  1
    <class 'dict'>
    Optional argument (args):  2
    Optional argument (args):  3
    Optional argument (args):  4
    Optional argument k2 (kwargs): 6
    Optional argument k1 (kwargs): 5
  • 相关阅读:
    输入分隔符
    GO
    match|align|identify|cover_rate
    KEGG
    InterProScan
    Functional annotation
    GeneWise
    get middle lines
    goland debug web app with urfave cli
    go mod proxy
  • 原文地址:https://www.cnblogs.com/zf-blog/p/14606285.html
Copyright © 2020-2023  润新知