Python的函数参数有哪些,含义和用法是什么
Admin 2022-05-20 群英技术资讯 530 次浏览
这是一个求等差数列和的函数,使用必需要传入一个参数n,这就是位置参数
def sum(n): sum=0 i=1 while i<=n: sum+=i i+=1 return sum result=sum(100) print(result)
默认参数就是,我在函数中已经将一个参数提前设置好了值,如果你没有传入这个参数的值,就会用我事先设置好的值,如果你传入了就用你的
我这里定义了一个求x的y次方的方法
def power(x,y=2): return x**y print(power((2))) print(power(2,3))
def printmessage(name,age,*args,gender): print(name,age,args,gender) print(type(args)) printmessage("赵四",40,12345456,"男")
首先来看一下这个问题,我把一个多值参数写在了一个位置参数的前面这会发生什么事情?
报错信息:找不到”gender“这个字段对应的值
printmessage("赵四",40,12,34,54,56,"男")
*args是一个多值参数,他把后面所有的值都给收纳了,所以我们传入值得时候,需要把对应参数名也写上,这样才能识别这是单独一个参数的值
def printmessage(name,age,*args,gender): print(name,age,args,gender) print(type(args)) printmessage("赵四",40,12,34,54,56,gender="男")
这个关键字参数还有什么用处呢,只要指定了参数名,我们可以不按函数里面设置的参数顺序传入值,但是一旦这样打乱顺序,多值参数就无法识别出哪里是他可以接收值的地方,所以我就传入了其他3个参数
def printmessage(name,age,*args,gender): print(name,age,args,gender) print(type(args)) printmessage(age=45, gender='男', name='刘能')
可能有人不相信上面的结论
我随便放哪个位置都是不能识别的
最后一个情况没有报错,但是这个语法是错误的,他会认定你传入的1就是name,但是后面再次出现了name,并且缺少值得问题还是没解决
那我们试试用args接收一个元组试试?
printmessage(age=45, gender='男', name='刘能',args=(1,2,3,4))
很遗憾,根本无法识别这个关键字
所以打乱顺序传值的时候千万别有多值参数
可变参数分为2种
接收元组参数:*args 一个*的是接收多个数据放入元组
接受字典参数:**args 两个*的接受的是k=v类型的数据,将他们放入一个字典
元组:
def sumN(*args): # args是参数名 # 要操作传入的参数 可以对args(相当于有参数构成的tuple)进行遍历 print(args, type(args)) sum = 0 for i in args: sum += i print(sum) sumN(1,2,3,5)
元组注意的事项就是,如果有参数在接受元组参数的后面,要用关键字参数传值
字典:
def printmessage(name,age,gender,**kw): print(name,age,gender,kw) print(type(kw)) printmessage("赵四",40,"男",address="象牙山",phonenumber="888888")
传入字典的多值参数后面是不能跟参数的,他只能放在函数参数的最后一个位置
还有,想用关键值传递的,传入的时候别乱调位置,要是到了**args的范围,就少了一个参数
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
我们知道线程池在python爬虫应用中,能提高爬虫的效率,但是很多朋友不了解python线程池还有很多其他优点,下面我们一起来看看python线程池使用的好处,下文还介绍了python线程池实例,有需要的朋友可以了解一下。
偶然从pytorch讨论论坛中看到的一个问题,KL divergence different results from tf,kl divergence 在TensorFlow中和pytorch中计算结果不同,平时没有注意到,记录下
这篇文章主要介绍了Python pyecharts绘制柱状图,文章介绍的柱状/条形图,通过柱形的高度/条形的宽度来表现数据的大小,感兴趣的小伙伴一起进入文章学习更详细内容吧<BR>
整个Spark 框架模块包含:Spark Core、 Spark SQL、 Spark Streaming、 Spark GraphX、 Spark MLlib,而后四项的能力都是建立在核心引擎之上。Spark Core:Spark的核心,Spark核心功能均由Spark Core模块提供...
本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于内置模块OS如何打造SHELL端文件处理器的相关内容,下面一起来看一下,希望对大家有帮助。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008