python - 传参总结 - *args 和 **kwargs

source

作者:耀凯考前突击大师
链接:https://www.jianshu.com/p/be92113116c8

 

 

指定参数的数据类型

https://blog.csdn.net/qq_42327755/article/details/87196150

当你写的函数方法,要被其他人调用时, 你想让他知道传入参数的数据类型, 可以这样定义
 
 
def demo(name: str, age: 'int > 0'=20)->str:  # ->str 表示该函数的返回值是str类型的
    print(name, type(name))
    print(age, type(age))
    return "hello world"  
demo(1, 2)      # 这里的参数1会显示黄色, 但是可以运行不会报错
 
# 1 <class 'int'>
# 2 <class 'int'>
 
 
demo('小小', 2)  # 正常显示
 
# 小小 <class 'str'>
# 2 <class 'int'>
 
"""
    以上是注解表达式的应用方法, 注解中最常用的就是  类(str 或 int )类型 和 字符串(如 'int>0')  
    
    注解不会做任何处理, 只是存储在函数的__annotations__属性(1个字典)中   return 返回的值的注解
    
    对于注解, python不做检查, 不做强制, 不做验证, 什么操作都不做.  换而言之, 注释对python解释器没有任何意义, 只是为了方便使用函数的人  
"""
print(demo.__annotations__)
{'name': <class 'str'>, 'age': 'int >0 ', 'return': <class 'str'>}

所以这样指定数据类型也没啥用,还不如在函数注释里面把参数数据类型写清楚。

 

多值参数:***

实际上真正的Python参数传递语法是****args**kwargs只是一种约定俗成的编程实践。我们也可以写成*vars**kvars

*args**kwargs一般是用在函数定义的时候。二者的意义是允许定义的函数接受任意数目的参数

也就是说我们 在函数被调用前 并不知道也不限制将来函数可以接收的参数数量。在这种情况下我们可以使用*args**kwargs


*args的使用

*args用来表示函数接收可变长度的非关键字参数列表作为函数的输入。(用来发送一个非键值对的可变数量的参数列表给一个函数。) 

def test_args(normal_arg, *args):
    print("first normal arg:" + normal_arg)
    for arg in args:
        print("another arg through *args :" + arg)

test_args("normal", "python", "java", "C#")
first normal arg: normal
another arg through *args : python
another arg through *args : java
another arg through *args :C#

**kwargs的使用

许你将不定度的键值对, 为参数传递给 如果想要在一名字的参数, 你应该使用**kwargs

def test_kwargs(**kwargs):
    if kwargs is not None:
        for key, value in kwargs.iteritems():
            print("{} = {}".format(key,value))
        # Or you can visit kwargs like a dict() object
        # for key in kwargs:
        #    print("{} = {}".format(key, kwargs[key]))
test_kwargs(name="python", value="5")
name = python
value = 5

 

https://blog.csdn.net/lijing742180/article/details/94169446

def demo(num, *args, **kwargs):

    print(num)
    print(args)
    print(kwargs)

demo(1, 2, 3, 4, 5, name="小明", age=18, gender=True)

输出:
1
(2, 3, 4, 5)
{'name': '小明', 'age': 18, 'gender': True}
def demo(*args, **kwargs):

    print(args)
    print(kwargs)

gl_nums = (1, 2, 3)
gl_xiaoming = {"name": "小明", "age": 18}

"变量名前必须要加 * 号,否则不能无法正常拆包"

"错误演示(不加 * 号):"
demo(gl_nums, gl_xiaoming)
输出:
((1, 2, 3), {'name': '小明', 'age': 18})
{}

"正确演示(加 * 号):"
demo(*gl_nums, **gl_xiaoming)
输出:
(1, 2, 3)
{'name': '小明', 'age': 18}

 

使用*args**kwargs来调用函数

接收普通输入参数的函数, 可以用  *args**kwargs来 直接调用这个函数。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值