博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
重拾Python学习(二)----------函数
阅读量:4126 次
发布时间:2019-05-25

本文共 1763 字,大约阅读时间需要 5 分钟。

本文参考:

函数定义

def function: return pass

函数可以同时返回多个值,但其实就是一个tuple。

函数参数

位置参数

def power(x, n)

默认参数

def power(x, n=2)

默认参数必须指向不变对象strNonetuple

可变参数

def calc(*numbers)

在函数内部,参数numbers接收到的是一个tuple
如果已经有一个list或者tuple,要调用一个可变参数:

>>> nums = [1, 2, 3]>>> calc(*nums)14

*nums表示把nums这个list的所有元素作为可变参数传进去

这里的 * 并非C中的指针?

关键字参数

def person(name, age, **kw)

>>> extra = {
'city': 'Beijing', 'job': 'Engineer'}>>> person('Jack', 24, **extra)name: Jack age: 24 other: {
'city': 'Beijing', 'job': 'Engineer'}

**extra表示把extra这个dict的所有key-value用关键字参数传入到函数的**kw参数

命名关键字参数

def person(name, age, *, city, job)

和关键字参数**kw不同,命名关键字参数需要一个特殊分隔符**后面的参数被视为命名关键字参数

>>> person('Jack', 24, city='Beijing', job='Engineer')Jack 24 Beijing Engineer

如果函数定义中已经有了一个可变参数,后面跟着的命名关键字参数就不再需要一个特殊分隔符*了:

def person(name, age, *args, city, job)

使用命名关键字参数时,如果没有可变参数,就必须加一个*作为特殊分隔符。如果缺少*,Python解释器将无法识别位置参数和命名关键字参数

def person(name, age, city, job):    # 缺少 *,city和job被视为位置参数    pass
参数组合

参数定义的顺序必须是:必选参数、默认参数、可变参数、命名关键字参数和关键字参数。

def f1(a, b, c=0, *args, **kw):    print('a =', a, 'b =', b, 'c =', c, 'args =', args, 'kw =', kw)def f2(a, b, c=0, *, d, **kw):    print('a =', a, 'b =', b, 'c =', c, 'd =', d, 'kw =', kw)
>>> f1(1, 2)a = 1 b = 2 c = 0 args = () kw = {
}>>> f1(1, 2, c=3)a = 1 b = 2 c = 3 args = () kw = {
}>>> f1(1, 2, 3, 'a', 'b')a = 1 b = 2 c = 3 args = ('a', 'b') kw = {
}>>> f1(1, 2, 3, 'a', 'b', x=99)a = 1 b = 2 c = 3 args = ('a', 'b') kw = {
'x': 99}>>> f2(1, 2, d=99, ext=None)a = 1 b = 2 c = 0 d = 99 kw = {
'ext': None}
>>> args = (1, 2, 3, 4)>>> kw = {
'd': 99, 'x': '#'}>>> f1(*args, **kw)a = 1 b = 2 c = 3 args = (4,) kw = {
'd': 99, 'x': '#'}>>> args = (1, 2, 3)>>> kw = {
'd': 88, 'x': '#'}>>> f2(*args, **kw)a = 1 b = 2 c = 3 d = 88 kw = {
'x': '#'}

转载地址:http://iuhpi.baihongyu.com/

你可能感兴趣的文章
Redis安装
查看>>
CSDN加好友,加关注,有ID怎么搜索
查看>>
记录一下eclipse 里maven子父项目怎么让它树状图显示
查看>>
刚装上sqlserver连接对象资源的服务器名称都忘了,已解决
查看>>
记录一下C# 开发里面的遇到内存释放,内存占用的问题
查看>>
想成为云计算大数据Spark高手,看这里!
查看>>
大数据开发:剖析Hadoop和Spark的Shuffle过程差异
查看>>
Hadoop与大数据的关系,学大数据就要学Hadoop!
查看>>
大数据开发:剖析Hadoop和Spark的Shuffle过程差异
查看>>
大数据时代,我们都是透明人!
查看>>
大数据打脸性别偏见
查看>>
Hadoop大数据平台开发与案例分析
查看>>
深入解读大数据框架Hadoop之HDFS架构
查看>>
Hadoop 不再权威,开源大数据的未来何去何从?
查看>>
2019年最新Hadoop大数据开发学习路线图
查看>>
数据挖掘十大经典算法
查看>>
写给大数据开发初学者的话
查看>>
大数据开发全套软件在这里
查看>>
玩转大数据开发工具--上篇
查看>>
大数据开发的通用步骤
查看>>