day12-Python-函数进阶
创始人
2025-06-01 18:23:04
0

Python-函数进阶

一.返回值

1.return的作用

注意:return只能在函数体中使用
1)将数据作为函数的返回值返回
2)结束函数(执行函数体的时候如果遇到return,函数直接结束)
def func1():print('+++++++')return 100print('-------')print('=======')print(func1())   # 100
def func2():print('+++++++')returnprint('-------')print('=======')print(func2())
def func3(n):# n = 5for x in range(1, n):if x % 3 == 0:return xprint(f'x:{x}')print(func3(5))
"""
x: 1
x: 2 
x: 3
x:4
Nonex:1
x:2
3
"""

二.函数作用域

1.变量作用域

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

2.全局变量和局部变量

"""
1)全局变量
python中没有定义在函数中或者类中的变量默认都是全局变量。
作用域:从定义开始到程序结束2)局部变量
定义站在函数中的变量就是局部变量(形参也是局部变量)。
作用域:从定义开始到函数结束
"""
a是全局变量
a = 100
x和b都是全局变量
for x in range(5):b = 200print(f'外面使用a:{a}')
print(f'外面使用x:{x}')
print(f'外面使用b:{b}')for y in range(3):print(f'循环里面a:{a}')print(f'循环里面b:{b}')print(f'循环里面x:{x}')
def fun1():print(f'函数里面a:{a}')print(f'函数里面b:{b}')print(f'函数里面x:{x}')fun1()
m 和 n 是局部变量
def func2(m):n = 1000print(f'函数里面m:{m}')print(f'函数里面n:{n}')func2(100)# print(f'函数外面m:{m}')
# print(f'函数外面n:{n}')

3.全局变量和局部变量的存储原理

"""
1)全局变量默认保存在全局栈区间,全局栈区间会在程序结束后自动释放。2)调用函数的时候系统会自动为这个函数创建一个临时栈区间,用来保存在函数中产生的数据(局部变量
就是保存在函数对应的临时栈区间中的),函数对应的临时栈区间会在函数调用结束的时候自动释放3)在函数中可以通过关键字global修改局部变量的保存方式,让局部变量保存在全局栈区间中"""
name = '小明'def func3():# 在函数内部定义全局变量用globalglobal numnum = 10# 在函数内部修改全局变量的值用globalglobal namename = '小花'func3()print(num)
print(name)

三.匿名函数

1.匿名函数 - 没有名字的函数

"""
函数名 = lambda 形参列表:返回值相当于:
def 函数名(形参列表):return 返回值注意:
1)匿名函数的形参至少一个
2)匿名函数的调用和普通函数一样
3)无默认值的类型说明在匿名函数中不能用
"""
案例:定义一个匿名函数,求任何两个数的和
sum_1 = lambda num1=1, num2=2: num1 + num2result = sum_1(100, 2)
print(result)  # 102result = sum_1(num1=100, num2=2)
print(result)result = sum_1()
print(result)  # 3
练习:定义一个匿名函数,判断指定的年是否闰年
is_leap_year = lambda year=2000: year % 400 == 0 or (year % 4 == 0 and year % 100 != 0)
print(is_leap_year(2001))

四.实参高阶函数

1.实参高阶函数

函数的参数是函数的函数就是实参高阶函数
给参数是函数的参数传参:a.使用普通函数得函数名 b.使用匿名函数
重点:掌握系统或者第三方提供的实参高阶函数的用法
常见的实参高阶:max、min、sorted、列表.sort、map、reduce
def func1(x):print(x)func1(10)
func1('abc')
func1([10, 20])
func1({'a': 10})
def func2(x):print(x * 2)func2(10)
func2(1.23)
func2('abc')
func2([10, 20])
func2((100, 200))
def func3(x):print(x + 10)func3(100)
func3(1.23)
func3(True)
def func4(x):print(x[1])func4('abc')
func4([10, 20])
func4({1: 100, 'a': 200})
def func5(x):print(x.split('+'))func5('abc')
# func6就是一个实参高阶函数
def func6(x):# x = tx()     # t()def t():print('t函数')func6(t)
# func7是实参高阶函数
def func7(x):# x = t2# x = lambda n1, n2: n1 + n2print(x(10, 20) + 30)# print(t2(10, 20) + 30)  print(200 + 30)# print(30 + 30)def t2(n1, n2):# n1 = 10, n2 = 20return n1 * n2      # return 200func7(t2)
func7(lambda n1, n2: n1 + n2)

五.常见实参高阶函数

常见的实参高阶函数

1.max、min、sorted、列表.sort

"""
1)max(序列)  -  直接比较序列中元素的大小求最大值2)max(序列, key=函数)  -  按照函数制定的规则比较序列中元素的大小获取最大值
函数的要求:
a.有且只有一个参数(这个参数代表序列中的每个元素)
b.有一个返回值(返回值就是比较对象)
"""
nums = [83, 67, 19, 22, 80, 77, 93]
print(max(nums))
案例:求个位数最大的元素
nums = [83, 67, 19, 22, 80, 77, 93]
result = max(nums, key=lambda item: item % 10)
print(result)       # 19
案例:求nums中绝对值最大的元素
nums = [8, -283, 89, 100, 82, -34]
result = max(nums, key=lambda item: item ** 2)
print(result)       # -283
案例:求students中分数最高的学生
students = [{'name': 'stu1', 'age': 18, 'score': 90},{'name': 'stu2', 'age': 22, 'score': 98},{'name': 'stu3', 'age': 25, 'score': 78},{'name': 'stu4', 'age': 19, 'score': 81},{'name': 'stu5', 'age': 20, 'score': 92}
]
result = max(students, key=lambda item: item['score'])
print(result)
案例:按照分数的高低对学生从大到小排序
result = sorted(students, key=lambda item: item['score'], reverse=True)
print(result)
练习1:求list1中长度最长的字符串
list1 = ['你好', 'hello', 'how are you', 'thank you! and you?', '好好学习,天天向上']
result = max(list1, key=lambda item: len(item))
print(result)
练习2:求nums中十位数最小的元素
nums = [92, 129, 37, 99, 150, 501]
result = min(nums, key=lambda item: item // 10 % 10)
print(result)
练习3:将所有的学生按照年龄值从小到大排序
students = [{'name': 'stu1', 'age': 18, 'score': 90},{'name': 'stu2', 'age': 22, 'score': 98},{'name': 'stu3', 'age': 25, 'score': 78},{'name': 'stu4', 'age': 19, 'score': 81},{'name': 'stu5', 'age': 20, 'score': 92}
]result = sorted(students, key=lambda item: item['age'])
print(result)
students.sort(key=lambda item: item['age'])
print(students)
练习4:求nums中各个位之和最大的元素
nums = [123, 78, 90, 201, 192, 330]
# 123  -> 1 + 2 + 3
# '123' -> '1'、'2'、'3', [1, 2, 3]
# result = max(nums, key=lambda item:item%10 + item//10%10 + item//100)
# print(result)
匿名函数
# 法1:
result1 = max(nums, key=lambda item: sum(int(x) for x in str(item)))
print(result1)
# 法2:
# 123 -> eval('1+2+3')
# 123 -> '123'  -> '+'.join('123') -> '1+2+3'
result2 = max(nums, key=lambda item: eval('+'.join(str(item))))
print(result2)
自定义普通函数
# 法3:
def t(item):sum1 = 0for x in str(item):sum1 += int(x)return sum1result = max(nums, key=t)
print(result)

2.map - 基于原序列中的元素创建一个新的序列

"""
1)map(函数, 序列)  -  通过函数描述的规则基于原序列中的元素创建一个新的序列
函数的要求:
a.有且只有一个参数(代表后面这个序列中的每个元素)
b.有一个返回值(返回值就是新序列中的元素)2)map(函数, 序列1, 序列2)
函数要求:
a.有且只有2个参数(代表后面这两个序列中的每个元素)
b.有一个返回值(返回值就是新序列中的元素)3)map(函数, 序列1, 序列2, 序列3,..)
"""
案例1:将nums中所有的元素乘以10
nums = [19, 870, 34, 61, 78]
result = map(lambda item: item * 10, nums)
print(result)   # 
print(list(result))   # [190, 8700, 340, 610, 780]
案例2:获取nums中所有元素的个位数
result = map(lambda item: item % 10, nums)
print(list(result))     # [9, 0, 4, 1, 8]
案例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]
练习1:获取names中每个人的姓
names = ['何晓东', '张三', '李四', '王五', '王二', '赵六']
result = map(lambda item: item[0], names)
print(list(result))
练习2:
students = [{'name': 'stu1', 'age': 18, 'score': 90},{'name': 'stu2', 'age': 22, 'score': 98},{'name': 'stu3', 'age': 25, 'score': 78},{'name': 'stu4', 'age': 19, 'score': 81},{'name': 'stu5', 'age': 20, 'score': 92}
]
subjects = ['电子信息', '金融数学', '园林设计', '经济', '计算机软件']# ['电子信息-stu1', '金融数学-stu2',....]
result = map(lambda item1, item2: item2+'-'+item1['name'], students, subjects)
result = map(lambda item1, item2: f'{item2}-{item1["name"]}', students, subjects)
print(list(result))

3.reduce - 将序列中的元素合并成一个数据(基于原序列中所有的元素得到一个数据)

"""
reduce(函数, 序列, 初始值)  -  按照函数制定的规则将序列中的元素合并成一个数据
函数的要求:
a.有且只有两个参数(第一个参数指向初始值,第二个参数代表序列中的每个元素)
b.需要一个返回值(返回值就是合并规则)初始值:累积求数值和,初始值是0累积求数值乘积,初始值是1字符串合并,初始值是空串
"""
from functools import reduce
nums = [12, 301, 40, 55, 112]# 案例1:12 + 301 + 40 + 55 + 112 的结果
# 0 + 12 + 301 + 40 + ... + 112
result = reduce(lambda x, item: x + item, nums, 0)
print(result)# 案例:12 * 301 * 40 * 55 * 112 的结果
# 1 * 12 * 301 * ... * 112
result = reduce(lambda x, item: x * item, nums, 1)
print(result)# 案例:123014055112  -> '123014055112'
# '' + '12' + '301' + '40' + ... + '112'
# '' + str(12) + str(301) +... + str(112)
result = reduce(lambda x, item: x + str(item), nums, '')
print(result)       # '123014055112'# 练习:2+1+0+5+2
nums = [12, 301, 40, 55, 112]
# 0 + 2 + 1 + 0 + 5 + 2
# 0 + 12 % 10 + 301 % 10 + ... + 112 % 10
result = reduce(lambda x, item: x + item % 10, nums, 0)
print(result)

六.迭代器

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))     # []

相关内容

热门资讯

宋清辉:经常喜欢抛头露面的表演... 宗庆后事件以及其他案例的启示在于,在信息爆炸的时代,任何刻意塑造的“完美人设”都如同沙堡,经不起时间...
贴心服务赢得客户赞誉 本报晋城讯 近年来,阳城农商银行始终坚守金融为民初心,以“我为群众办实事”为行动指南,持续推进金融服...
正裕工业:拟定增募资不超4.5... 正裕工业晚间公告称,公司拟定增募资不超过4.5亿元,扣除发行费用后的净额用于正裕智造园(二期)项目及...
《2024年全国海水利用报告》... 中国日报7月19日电(记者 赵磊)记者从自然资源部获悉,近日,该部海洋战略规划与经济司发布《2024...
重磅揭晓!2025国内舆情公关... 在数字化浪潮与全球化竞争交织的2025年,舆情公关已从“幕后灭火”跃升为品牌价值增长的核心引擎。今日...
“华尔街收购之王”KKR入局大... 《科创板日报》7月18日讯(记者 徐赐豪),消费并购热升温。 市场监管总局7月16日发布的《2025...
响应即时零售行业自律倡议!淘宝... 来源:新浪科技 新浪科技讯 7月18日下午消息,响应即时零售行业自律倡议,淘宝、饿了么今日双双发文称...
和讯投顾韩东峰:大盘本周消化上... 今天上证指数继续小幅震荡攀升,本周市场状态可以用两句话来概括。第一,针对上周五的上影线,市场进行了消...
三花智控成年内港股第三大IPO... 每经记者:黄婉银 每经编辑:魏文艺 |2025年7月21日 星期一| NO.1双林股份筹划港股上市 ...
保德农商银行:存款保险护万家 ... 近日,保德农商银行组织辖内营业网点以多样化形式开展 “存款保险十周年” 主题宣传活动,切实推进存款保...
和讯投顾黄儒琛:情绪修复力度过... 7月18日,和讯投顾黄儒琛称,情绪修复力度过大,今日需先关注市场分歧。开盘大概率会有一波冲高,若指数...
“保险+期货”展现出强大生命力 ■田耿文 “保险+期货”已稳健运行十年,展现出强大的生命力和广阔的发展前景。 从“保价格”到“保收入...
首尾规模相差超百倍,券商如何破... 【导读】首尾规模相差超百倍,券商如何破局养老金融? 中国基金报记者 莫琳 “今年上半年,个人养老金基...
68.8%!内需扛鼎中国经济“... “从数据可以看到,内需尤其是消费,是促进GDP增长的主动力。”在7月15日国务院新闻办公室召开的新闻...
昊天国际建设(01341.HK... 香港联交所最新资料显示,7月18日,昊天国际建设(01341.HK)股东将股票由华盛资本证券转入海通...
8年前239亿元天价拿地,曾规... 每日经济新闻资料图 曾规划建设“中国第一高楼”的世茂深港国际中心,在经历两次法拍失利、以物抵债之后,...
周一,国内家居五金龙头来了! 今年以来,新股市场交投活跃。Choice数据显示,截至7月20日,2025年共有55只新股上市,上市...
证监会发布指引完善会计监管规则... 本文转自【新华社】 新华社北京7月19日电 《中国证券报》19日刊发文章《证监会发布指引完善会计监管...
A股“躺赢”3600点?知名大... A股“躺赢”3600点?知名大V猫笔刀曝港美股20%个税细节,四大焦点问题,我国已与100多国实现信...
“两新”政策拉动装备制造业快速... 国家统计局最新发布的数据显示,上半年,全国规模以上工业增加值同比增长6.4%。其中,规模以上装备制造...