news 2026/6/1 2:36:58

Python 函数专项练习:6 道编程题从入门到精通

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python 函数专项练习:6 道编程题从入门到精通

配套专栏:Python 全栈修炼之路 第 07 篇《函数 —— 代码复用的基石》

难度分布:⭐ → ⭐⭐ → ⭐⭐ → ⭐⭐⭐ → ⭐⭐⭐ → ⭐⭐⭐⭐

核心覆盖:*args/**kwargs、闭包、装饰器、递归、lru_cache、高阶函数、LEGB 作用域、延迟绑定


题目一:通用函数调用器 ⭐

📌 题目描述

编写函数call_function(func, args=None, kwargs=None),实现一个通用的函数调用器:

defadd(a,b,c=0):returna+b+c# 位置参数调用call_function(add,args=[1,2])# 3call_function(add,args=[1,2,3])# 6# 关键字参数调用call_function(add,kwargs={"a":1,"b":2})# 3# 混合调用call_function(add,args=[1],kwargs={"b":2,"c":10})# 13

💡 编程思路

这道题考察*args**kwargs的解包与转发

  1. 函数需要接收一个可调用对象func,以及可选的位置参数列表args和关键字参数字典kwargs
  2. 使用*解包位置参数列表,**解包关键字参数字典。
  3. 通过func(*args, **kwargs)实现动态调用。

关键点None的默认值处理 —— 当argskwargsNone时,应替换为空列表/空字典。

🖥️ 参考代码

defcall_function(func,args=None,kwargs=None):""" 通用函数调用器 参数: func: 可调用对象 args: 位置参数列表 kwargs: 关键字参数字典 """args=argsor[]kwargs=kwargsor{}returnfunc(*args,**kwargs)defcall_function_safe(func,args=None,kwargs=None):"""安全版本:捕获异常并返回友好错误信息"""args=argsor[]kwargs=kwargsor{}try:returnfunc(*args,**kwargs)exceptTypeErrorase:returnf"调用失败:{e}"# 测试if__name__=="__main__":defadd(a,b,c=0):returna+b+cdefgreet(name,greeting="你好"):returnf"{greeting},{name}!"defvar_args(*args,**kwargs):returnf"args={args}, kwargs={kwargs}"# 位置参数print(call_function(add,args=[1,2]))# 3print(call_function(add,args=[1,2,3]))# 6# 关键字参数print(call_function(add,kwargs={"a":1,"b":2}))# 3print(call_function(greet,kwargs={"name":"张三"}))# 你好, 张三!# 混合调用print(call_function(add,args=[1],kwargs={"b":2,"c":10}))# 13# 可变参数函数print(call_function(var_args,args=[1,2,3],kwargs={"x":99}))# args=(1, 2, 3), kwargs={'x': 99}# 错误处理print(call_function_safe(add,args=[1]))# 缺少参数print(call_function_safe(add,args=[1,2,3,4]))# 参数过多

🔗 关联知识点

知识点说明
*args解包将列表展开为位置参数
**kwargs解包将字典展开为关键字参数
or []惯用法None时替换为空列表
TypeError捕获参数不匹配时的异常

题目二:闭包实现带历史记录的计算器 ⭐⭐

📌 题目描述

使用闭包实现一个带历史记录的计算器工厂make_calculator(),每次调用返回独立的计算器实例:

calc1=make_calculator()calc1.add(5)calc1.add(3)calc1.subtract(1)print(calc1.result())# 7print(calc1.history())# ['+5', '+3', '-1']calc2=make_calculator()calc2.multiply(4)calc2.add(6)print(calc2.result())# 4 (独立的实例)

💡 编程思路

这道题考察闭包的状态保持能力

  1. make_calculator()内部维护totalhistory两个自由变量。
  2. 返回的内部函数通过nonlocal修改这些变量。
  3. 每次调用make_calculator()都会创建独立的闭包实例,互不干扰。

关键点:闭包通过__closure__捕获外部变量,即使外部函数已返回,变量仍存活。

🖥️ 参考代码

defmake_calculator(initial=0):""" 创建带历史记录的计算器闭包 返回: 包含 add/subtract/multiply/divide/result/history/clear 方法的对象 """total=initial history=[]def_update(value,symbol):nonlocaltotal total=value history.append(f"{symbol}{value}")defadd(n):_update(total+n,f"+{n}")returntotaldefsubtract(n):_update(total-n,f"-{n}")returntotaldefmultiply(n):_update(total*n,f"*{n}")returntotaldefdivide(n):ifn==0:raiseZeroDivisionError("除数不能为零")_update(total/n,f"/{n}")returntotaldefresult():returntotaldefget_history():returnhistory.copy()defclear():nonlocaltotal total=initial history.clear()defundo():"""撤销上一步操作(重新计算历史)"""nonlocaltotalifnothistory:returnhistory.pop()total=initial# 重新执行所有历史操作forrecordinhistory:op=record[0]val=float(record[1:])ifop=='+':total+=valelifop=='-':total-=valelifop=='*':total*=val
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/1 2:33:36

告别混乱日志!用CAPL的setLogFileName函数,实现自动化测试日志的精准归档

告别混乱日志!用CAPL的setLogFileName函数实现自动化测试日志的精准归档在汽车电子测试领域,日志文件就像黑匣子记录仪——它们承载着测试过程中每一个关键信号和异常事件。但当数百个测试用例产生的日志文件散落在不同目录,命名毫无规律时&a…

作者头像 李华
网站建设 2026/6/1 2:32:23

SCREME框架:低成本高可靠内存ECC技术解析

1. SCREME框架:内存可靠性的革新设计在数据中心和高端计算领域,内存可靠性一直是系统设计的关键挑战。随着DDR5内存的普及和数据量的爆炸式增长,传统错误检测与纠正(ECC)技术正面临前所未有的压力。SCREME框架应运而生…

作者头像 李华
网站建设 2026/6/1 2:28:17

用Python手把手教你实现一个简单的感知器(附AND/OR逻辑门完整代码)

用Python从零构建感知器:AND/OR逻辑门的实战演练第一次接触神经网络时,很多人会被复杂的数学公式吓退。但事实上,神经网络的基础单元——感知器(Perceptron)——其核心思想简单得令人惊讶。本文将带你用不到100行Pytho…

作者头像 李华