"""
1)语法
函数名 = lambda 形参列表: 返回值
相当于:
def 函数名(形参列表):
return 返回值
注意:匿名函数除了定义以及参数类型说明和普通函数不一样,其他都是一样的
"""
sum1 = lambda num1, num2: num1 + num2
result = sum1(10, 30)
print(result)
result = sum1(12.5, 2)
print(result)
func1 = lambda a, b=20, c=30: a + b + c
result = func1(10)
print(result)
result = func1(a=1, b=2, c=3)
print(result)
result = func1(100, 200, c=300)
print(result)
is_leap_year = lambda year: year % 4 == 0 and year % 100 != 0 or year % 400 == 0
print(is_leap_year(2000))
"""
全局变量: 没有定义在函数和类里面的变量都是全局变量,全局变量的作用域是从定义开始到程序结束的任何位置
"""
a = 10
print(f'函数外面;类外面, a:{a}')
def func1():
print(f'函数里面,a:{a}')
func1()
class A:
print(f'类里面,a:{a}')
for x in range(5):
b = 20
print(f'循环里面b, x: {b}, {x}')
print(f'循环外面b, x: {b}, {x}')
def func2():
print(f'函数里面b, x: {b}, {x}')
func2()
"""
局部变量:定义在函数中的变量是局部变量(形参也是局部变量),局部变量的作用域是从定义开始到函数结束
"""
def func3(m):
c = 30
print(f'函数里面m, c: {m}, {c}')
func3(100)
"""
全局变量保存在全局的栈区间,全局栈区间是在程序结束的时候才会自动释放;
每次调用函数的时候系统会自动为这个函数创建一个临时的栈区间(从C开始就是这样),用来保存函数运行过程中产生的数据,所以局部变量也是
保存在这个临时栈区间中的。当函数调用结束这个临时栈区间会自动释放。
"""
"""
作用1:在函数内部去修改全局变量的值
作用2:在函数内部定义全局变量
注意:global只能在函数内部使用,使用的时候必须在变量第一次使用之前
"""
abc = 100
name = '小明'
gender = '男'
def func4():
abc = 200
print(f'函数里面的abc:{abc}')
global name
name = '小花'
print(f'函数里面name:{name}')
global age
age = 18
global gender
print(gender)
gender = '女'
func4()
print(f'函数外面的abc:{abc}')
print(f'函数外面name:{name}')
print(f'函数外面age:{age}')
a = 10
def b(x):
print('我是函数!')
return x*2
print(a)
print(b)
print(type(a))
print(type(b))
m = a
n = b
print(m + 100)
result = n(10)
print(result)
list1 = [a, b, b(2)]
print(list1)
print(list1[1](3))
def func1(x):
print(10 + x(1, 2))
def temp(a: int, b: int):
return a + b
func1(temp)
def func2():
def func3():
return 100
return func3
print(func2()())
"""
max(序列, key=函数) - 根据函数指定的规则来获取序列中最大的元素
函数的要求:a.有且只有一个参数,这个参数代表序列中的每个元素
b.有一个返回值,返回值就是比较对象
"""
nums = [10, 29, 81, 23]
def temp(x):
return x % 10
result = max(nums, key=temp)
print(result)
nums = [10, '23.8', 34, '89']
result = max(nums, key=lambda x: float(x))
print(result)
students = [
{'name': 'stu1', 'age': 29, 'score': 59},
{'name': 'stu2', 'age': 23, 'score': 89},
{'name': 'stu3', 'age': 12, 'score': 76},
{'name': 'stu4', 'age': 22, 'score': 77}
]
result = max(students, key=lambda x: x['score'])
print(result)
result = sorted(students, key=lambda x: x['age'])
print(result)
nums = [70, 89, 102, 34, 67]
def temp(x):
sum1 = 0
for i in str(x):
sum1 += int(i)
return sum1
result = min(nums, key=temp)
print(result)
"""
1) map(函数, 序列)
函数:a.有且只有一个参数,参数指向后面序列中的每个元素
b.有一个返回值,返回值就是新序列中的元素
2) map(函数, 序列1, 序列2)
函数:a.有且只有2个参数,分别指向后面两个序列中的元素
b.有一个返回值,返回值就是新序列中的元素
3)map(函数, 序列1, 序列2, 序列3)
函数:a.有且只有3个参数,分别指向后面3个序列中的元素
b.有一个返回值,返回值就是新序列中的元素
map(函数, 序列1, 序列2, 序列3, 序列4,...)
# 注意:map函数的返回值是一个map对象(本质是一个序列)
"""
nums = [12, 34, 56, 67, 19, 83]
result = list(map(lambda x: x % 10, nums))
print(result)
nums = [12, 34, 56, 67, 19, 83]
strs = ['a', 'b', 'c', 'd', 'e', 'f']
result = map(lambda x1, x2: str(x1)+x2, nums, strs)
print(list(result))
names = ['stu1', 'stu2', 'stu3', 'stu4', 'stu5']
ages = [18, 20, 45, 78, 26]
score = [90, 87, 69, 71, 82]
result = map(lambda n, a, s: {'name': n, 'age': a, 'score': s}, names, ages, score)
print(list(result))
"""
注意:reduce在使用前必须先导入
reduce(函数, 序列, 初始值)
函数的要求:a. 有且只有两个参数:第一个参数指向初始值,第二个参数指向序列中的每个元素
b. 有一个返回值,返回值需要描述清楚合并方式
"""
from functools import reduce
nums = [10, 23, 89, 34]
result = reduce(lambda x1, x2: x1+x2, nums, 0)
print(result)
nums = [10, 23, 89, 34]
result = reduce(lambda x1, x2: x1 + x2 % 10, nums, 0)
print(result)
nums = [10, 23, 89, 34]
result = reduce(lambda x1, x2: x1 + str(x2), nums, '')
print(result)
nums = [10, 23, 89, 34]
result = reduce(lambda x1, x2: x1 * x2, nums, 1)
print(result)