函数基础与lambda函数

2019-05-18  本文已影响0人  Vector_Wan

主要包括:

函数的定义

def 函数名(参数=默认值):
    
    pass

调用: 函数名(实参)

def caculateNum(num):
    '''
    计算1 到 num 之间的累加和
    '''
    res = 0
    for i in range(1, num+1):
        res += i
    return res
    # 等价于 sum([i for i in range(1,num+1)])

caculateNum(100)
5050

查看函数的帮助文档主要有以下两种方式:

def ff():
    '''
    这是一个注释!!!
    '''
    pass

help(ff)
Help on function ff in module __main__:

ff()
    这是一个注释!!!
ff.__doc__
'\n    这是一个注释!!!\n    '

多文件调用:

import 文件名

调用的时候直接

文件名.函数名(参数)

例如:将上面的 caculateNum 函数保存在 caculation.py 中,调用格式为:sum = caculation.caculateNum(100)

注意此时一定要将文件放在同一个文件夹中,否则写成一个包

更多见模块:https://www.jianshu.com/p/62f110fa3f98

必须参数和关键字参数

参数必须以正确的顺序传入,调用的时候参数数量必须与声明时候保持一致。

# 错误示范
def f(name, age):
    print('I am %s, I am %d years old'%(name, age))
    
f('Vector')
---------------------------------------------------------------------------

TypeError                                 Traceback (most recent call last)

<ipython-input-3-9ab44abccbee> in <module>
      2     print('I am %s, I am %d years old'%(name, age))
      3 
----> 4 f('Vector')


TypeError: f() missing 1 required positional argument: 'age'
# 错误示范
f(18,'Vector')
  File "<ipython-input-3-abdece611031>", line 1
    f(18,'Vector')
        ^
SyntaxError: invalid character in identifier

使用关键字参数可以允许函数调用时与声明顺序不一致,Python 解释器能够用参数名字匹配参数值

# 关键字参数
f(age = 18, name = 'Vector')
I am Vector, I am 18 years old

默认参数缺省,参数没有传入,默认值会生效,默认值需要从右边先指定

def f(name, age, sex = 'male'):
    print('I am %s, I am %d years old'%(name, age))
    print('sex is %s'%sex)
    
f(name = 'Vector', age = 19)
I am Vector, I am 19 years old
sex is male

是否显示指定参数,以方便自己以后阅读为目的

匿名函数

语法:

lambda 参数:表达式

冒号前面是参数,可以含有多个

后面是表达式,只能有一个表达式,不写return返回值就是表达式的结果。

优点:减少代码量,使代码看起来更优雅

# 普通函数
def rect (x, y):
    return x * y
area = rect(3,5)
area
15
# 使用 lambda 表达式:
res = lambda x, y: x * y
print(res(3, 5))
15

在三元运算时也经常使用 lambda 函数,来看看下面这两个例子:

def ifEmpty(lt):
    '''
    如果列表是空的就返回'是一个空列表',否则返回第一个元素
    '''
    s = '是一个空列表' if len(lt) == 0 else lt[0]
    return s

res = lambda lt: '是一个空列表' if len(lt) == 0 else lt[0]
    
print('使用普通函数:', ifEmpty(['11', 12]))
print('使用 lambda: ', res(['11', 12]))
使用普通函数: 11
使用 lambda:  11
def cal (x, y):
    if x > y :
        return x * y
    else:
        return x/y
    
cale= lambda x, y:x*y if x > y else x/y

print('使用普通函数', cal(3,3))
print('使用 lambda: ', cale(3,3))
使用普通函数 1.0
使用 lambda:  1.0

在字典列表排序中也经常使用 lambda 函数:

stus= [
    {'name': 'zhansan', 'age': 33},
    {'name': 'lisi', 'age': 12},
    {'name': 'wangwu', 'age': 58},
    {'name': 'zhaoliu', 'age': 18},
    {'name': 'tianqi', 'age': 77}
]
print('排序前:', stus)
# key 传入的是按照哪个元素为依据进行排序
res = sorted(stus, key = lambda x: x['age'], reverse = True)
print('排序后:', res)
排序前: [{'name': 'zhansan', 'age': 33}, {'name': 'lisi', 'age': 12}, {'name': 'wangwu', 'age': 58}, {'name': 'zhaoliu', 'age': 18}, {'name': 'tianqi', 'age': 77}]
排序后: [{'name': 'tianqi', 'age': 77}, {'name': 'wangwu', 'age': 58}, {'name': 'zhansan', 'age': 33}, {'name': 'zhaoliu', 'age': 18}, {'name': 'lisi', 'age': 12}]
sorted(stus, key = lambda item: ['age']) 
[{'name': 'zhansan', 'age': 33},
 {'name': 'lisi', 'age': 12},
 {'name': 'wangwu', 'age': 58},
 {'name': 'zhaoliu', 'age': 18},
 {'name': 'tianqi', 'age': 77}]

关于 sorted 函数见:
https://www.jianshu.com/p/a63546d1c945

上一篇 下一篇

猜你喜欢

热点阅读