#普通条件语句 i = 0 if i == 1: name = 'mike' else: name = 'mary' #三元运算 name = 'mike' if i == 1 else 'mary' # 定义函数(普通方式) def func(arg): return arg + 1 # 执行函数 result = func(123) # 定义函数(lambda表达式) my_lambda = lambda arg: arg + 1 # 执行函数 result = my_lambda(123)
lambda存在意义就是对简单函数的简洁表示
内置函数:
一、map
遍历序列,对序列中每个元素进行操作,最终获取新的序列。
描述:
map() 会根据提供的函数对指定序列做映射。
第一个参数function 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表。
语法:
map() 函数语法:
map(function, iterable, ...)
参数:
· function -- 函数,有两个参数
· iterable -- 一个或多个序列
返回值:
Python 2.x 返回列表。
Python 3.x 返回迭代器。
示例:
li = [11, 22, 33] new_list = map(lambda a: a + 100, li) print(list(new_list))#[111, 122, 133]
li = [11, 22, 33] sl = [1, 2, 3] new_list = map(lambda a, b: a + b, li, sl) print(list(new_list))#[12, 24, 36]
二、filter
对于序列中的元素进行筛选,最终获取符合条件的序列
描述
filter() 函数用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。
该接收两个参数,第一个为函数,第二个为序列,序列的每个元素作为参数传递给函数进行判,然后返回 True 或 False,最后将返回 True 的元素放到新列表中。
语法
以下是 filter() 方法的语法:
filter(function, iterable)
参数
· function -- 判断函数。
· iterable -- 可迭代对象。
返回值
返回列表
示例:
li = [11, 22, 33] new_list = filter(lambda arg: arg > 22, li) #filter第一个参数为空,将获取原来序列 print(list(new_list))#[33]
三、reduce
对于序列内所有元素进行累计操作
描述
reduce() 函数会对参数序列中元素进行累积。
函数将一个数据集合(链表,元组等)中的所有数据进行下列操作:用传给 reduce 中的函数 function(有两个参数)先对集合中的第 1、2 个元素进行操作,得到的结果再与第三个数据用 function 函数运算,最后得到一个结果。
语法
reduce() 函数语法:
reduce(function, iterable[, initializer])
参数
· function -- 函数,有两个参数
· iterable -- 可迭代对象
· initializer -- 可选,初始参数
返回值
返回函数计算结果。
示例:
from functools import reduce li = [11, 22, 33] result = reduce(lambda arg1, arg2: arg1 + arg2, li) print(result) # reduce的第一个参数,函数必须要有两个参数 # reduce的第二个参数,要循环的序列 # reduce的第三个参数,初始值