day12 - 函数

day12 函数

01 变量作用域

# 1. 变量作用域
"""
变量作用域指的是变量定义完成后可以使用的有效范围。
根据变量变量作用域的不同,可以将变量分为全局变量和局部变量两种。
"""

# 2. 全局变量和局部变量
"""
1)全局变量 
python中没有定义在函数中或者类中的变量默认都是全局变量。
作用域:从定义开始到程序结束

2)局部变量
定义在函数中的变量就是局部变量(形参也是局部变量)
作用域:从定义开始到函数结束
"""

# 3.全局变量和局部变量的存储原理
"""
1)全局变量默认保存在全局栈区间,全局栈区间会在程序结束后自动释放。

2)调用函数的时候系统会自动为这个函数创建一个临时栈区间,用来保存在函数中产生的数据(局部变量
就是保存在函数对应的临时栈区间中的),函数对应的临时栈区间会在函数调用结束的时候自动释放。

3)在函数中可以通过关键字global修改局部变量的保存方式,让局部变量保存在全局栈区间中。 
"""

02 匿名函数

# 1.匿名函数  -  没有名字的函数
"""
函数名 = lambda 形参列表:返回值

相当于:
def 函数名(形参列表):
    return  返回值
    
注意:
1)匿名函数的形参至少一个
2)匿名函数的调用和普通函数一样
3)无默认值的类型说明在匿名函数中不能用
"""
# 定义一个匿名函数,求任意两个数的和
sum_2 = lambda num1=1, num2=2: num1 + num2

result = sum_2(100, 200)
print(result)

result = sum_2(num1=10, num2=20)
print(result)

result = sum_2()
print(result)

# 练习:定义一个匿名函数,判断指定的年是否是闰年
is_leap_year = lambda year: year % 4 == 0 and year % 100 != 0 or year % 400 == 0
print(is_leap_year(2000))
print(is_leap_year(2001))

03 实参高阶函数

"""
# 实参高阶函数
# 函数的参数是函数的函数就是实参高阶函数
# 给参数是函数的参数传参:a.使用普通函数函数名;b.使用匿名函数
# 重点:掌握系统或者第三方库提供的实参高阶函数的用法
# 常见的实参高阶:max、min、sorted、列表.sort、map、reduce
"""
# 1. max、min、sorted、列表.sort
"""
1) max(序列)     -   直接比较序列中元素的大小求最大值

2) max(序列, key=函数)      -   按照函数制定的规则比较序列中元素的大小获取最大值
函数的要求:
    a. 有且只有一个参数(这个参数代表序列中的每个元素)
    b. 有一个返回值(返回值就是比较对象)
"""
# 求nums中各个位之和最大的元素
nums = [123, 78, 90, 201, 192, 330]
# 方法1:
result = max(nums, key=lambda item: sum([int(x) for x in str(item)]))
print(result)
# 方法2:
result = max(nums, key=lambda item: eval('+'.join(str(item))))
print(result)

# 2. map  -  基于原序列中的元素创建一个新的序列
"""
1)map(函数, 序列)  -  通过函数描述的规则基于序列中的元素创建一个新的序列
函数要求:
    a. 有且只有一个参数(代表后面的这个序列中每个元素)
    b. 有一个返回值(返回值就是新序列中元素)
    
2)map(函数, 序列1, 序列2)
函数要求:
    a. 有且只有2个参数(分别代表后面的两个序列中每个元素)
    b. 有一个返回值(返回值就是新序列中元素)

2)map(函数, 序列1, 序列2, 序列3,...)
"""
# 将nums1和nums2中相同位置上的元素相乘,得到一个新的序列
nums1 = [10, 20, 30, 10]
nums2 = [23, 30, 20, 55]
result = map(lambda i1, i2: i1 * i2, nums1, nums2)
print(list(result))     # # [230, 600, 600, 550]

# 3. reduce  -  将序列中元素合并成一个数据(基于原序列中所有的元素得到一个数据)
"""
reduce(函数, 序列, 初始值)     -       按照函数制定的规则将序列中的元素合并成一个数据
函数的要求:
    a. 有且只有两个参数(第一个参数指向初始值,第二个参数代表序列中的每个元素)
    b. 需要一个返回值 (返回值就是合并规则)
    
初始值: 累积求数值和,初始值是0
       累积求数值乘积,初始值是1
       字符串合并,初始值是''  
"""
from functools import reduce

nums = [12, 301, 40, 55, 112]
# 12 + 301 + 40 + 55 + 112 
result = reduce(lambda x, item: x + item, nums, 0)
print(result)
# 12 * 301 * 40 * 55 * 112 
result = reduce(lambda x, item: x * item, nums, 1)
print(result)
# 123014055112  -> '123014055112'
result = reduce(lambda x, item: x + str(item), nums, '')
print(result)

04 迭代器

# 1. 什么是迭代器(iter)
"""
1)迭代器是容器型数据类型(可以遍历,也转换成列表),无法直接提供一个迭代器,只能将其他序列转换成迭代器。
2)特点:
a.打印迭代器的时候无法查看到元素有哪些
b.无法通过len获取迭代器中元素的个数
c.如果要使用迭代器中的元素必须将元素从迭代器中取出来(取走),取走的元素会从迭代器中永远消失(用一个就少一个)

3)任何数据都可以作为迭代器的元素
"""
# 1)创建迭代器
i1 = iter('abc')
i2 = iter([10, 20, 30, 40])
i3 = iter((10, 1.23, 'abc', True, [10, 20]))

# 2)打印迭代器无法查看元素
print(i1)
print(i2)

# 3)迭代器无法统计个数
# print(len(i1))        # 报错!

# 2. 获取迭代器中的元素
"""
无论以任何方式获取到了迭代器中的某个元素,那么这个元素一定会从迭代器中消失。

1)获取单个元素: 
next(迭代器)  -  获取迭代器最前面的元素

2) 遍历迭代器
for 变量 in 迭代器:
    循环体
"""
print(next(i1))     # 'a'
print(next(i1))     # 'b'
print(next(i1))     # 'c'
# print(next(i1))     # 报错!

print(next(i2))     # 10
print(list(i2))     # [20, 30, 40]
# print(next(i2))     # 报错!

for x in i3:
    print(x)

print(list(i3))     # []
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值