定义函数用def,调用函数直接使用函数名加参数。函数可返回值、支持多种参数类型,作用域遵循LEGB规则,闭包能捕获外部变量,提升代码复用与灵活性。

在Python里,定义一个函数本质上就是给一段你想要重复使用的代码块一个名字,并指定它需要哪些输入(参数)。而调用函数,则是通过这个名字去执行那段代码,并提供它所需的具体输入。它让你的代码模块化、可读性更高,也更容易维护——想想看,如果一段逻辑需要在十个地方用到,你肯定不想复制粘贴十次,对吧?
在Python中定义函数,我们使用
def
一个最基本的函数定义和调用是这样的:
def greet(name):
"""
这个函数用于向指定的人打招呼。
"""
message = f"你好,{name}!欢迎来到Python的世界。"
print(message)
# 调用函数
greet("张三")
greet("李四")这里,
greet
name
greet("张三")name
立即学习“Python免费学习笔记(深入)”;
函数还可以返回一个值,使用
return
def add(a, b):
"""
计算两个数的和并返回。
"""
result = a + b
return result
# 调用函数并获取返回值
sum_result = add(5, 3)
print(f"5 + 3 = {sum_result}") # 输出:5 + 3 = 8
another_sum = add(10, 20)
print(f"10 + 20 = {another_sum}") # 输出:10 + 20 = 30我个人觉得,
return
当我们谈论函数的输入,也就是参数,Python提供了相当多的灵活性,这远不止简单的位置匹配。理解这些不同类型的参数,能让你写出更健壮、更易用的函数。
位置参数 (Positional Arguments):这是最常见的,参数的传递顺序必须与定义时一致。
def describe_person(name, age, city):
print(f"{name},{age}岁,来自{city}。")
describe_person("小明", 25, "北京")
# describe_person(25, "小明", "北京") # 顺序错误会导致逻辑混乱这种方式直观,但当参数多起来时,就容易搞混顺序。
关键字参数 (Keyword Arguments):通过
key=value
def describe_person(name, age, city):
print(f"{name},{age}岁,来自{city}。")
describe_person(age=30, city="上海", name="小红") # 顺序无关紧要我经常在参数较多或者有些参数含义不那么明显时,倾向于使用关键字参数。
默认参数 (Default Arguments):在定义函数时为参数指定一个默认值。如果调用时没有提供该参数,就使用默认值。
def send_email(receiver, subject="无主题", body=""):
print(f"发送邮件给:{receiver}")
print(f"主题:{subject}")
print(f"内容:{body}")
send_email("alice@example.com") # 使用默认主题和空内容
send_email("bob@example.com", subject="会议通知") # 仅覆盖主题这里有个小陷阱,默认值如果是可变对象(如列表、字典),在多次调用中会共享同一个对象,这通常不是你想要的。比如:
def append_item(item, my_list=[]): # 错误示范!
my_list.append(item)
return my_list
print(append_item(1)) # [1]
print(append_item(2)) # [1, 2] -- 意料之外!正确的做法是使用
None
def append_item_correct(item, my_list=None):
if my_list is None:
my_list = []
my_list.append(item)
return my_list
print(append_item_correct(1)) # [1]
print(append_item_correct(2)) # [2] -- 这才是我们想要的这个细节,我个人在初学时就踩过坑,所以每次用到默认参数都会特别留意。
*可变位置参数 (`args
)**:当你不知道函数会被传入多少个位置参数时,可以使用
def calculate_sum(*numbers):
total = 0
for num in numbers:
total += num
return total
print(calculate_sum(1, 2, 3)) # 6
print(calculate_sum(10, 20, 30, 40, 50)) # 150可变关键字参数 (`kwargs
)**:类似
def print_profile(**details):
for key, value in details.items():
print(f"{key}: {value}")
print_profile(name="小王", age=28, occupation="工程师")*args
**kwargs
函数的返回值是它与外部世界沟通的桥梁。理解如何高效、清晰地处理返回值,对于构建可维护的代码至关重要。
单个返回值:这是最常见的,函数执行计算后返回一个单一的结果。
def square(x):
return x * x
result = square(4) # result 为 16多个返回值(以元组形式):Python允许函数看起来返回多个值,实际上它返回的是一个元组。调用者可以通过解包(unpacking)来获取这些值。
def get_min_max(numbers):
if not numbers:
return None, None # 处理空列表的情况
return min(numbers), max(numbers)
data = [3, 1, 4, 1, 5, 9, 2, 6]
minimum, maximum = get_min_max(data)
print(f"最小值:{minimum},最大值:{maximum}") # 最小值:1,最大值:9
# 如果你只关心其中一个,也可以这样
_, max_val = get_min_max(data)
print(f"只取最大值:{max_val}")这种返回多个值的方式,我个人觉得非常Pythonic,比在其他语言中通过引用传递或者返回一个自定义对象要简洁得多。
不显式返回 (return None
return
return
None
def do_nothing():
pass # 什么也不做
def print_message(msg):
print(msg)
return # 显式返回None
result1 = do_nothing()
result2 = print_message("Hello")
print(f"do_nothing返回:{result1}") # do_nothing返回:None
print(f"print_message返回:{result2}") # print_message返回:None理解
None
None
None
尽早返回 (Early Exit):在函数内部,如果某个条件满足,可以立即
return
def is_positive(number):
if not isinstance(number, (int, float)):
return False # 如果不是数字,直接返回False
if number > 0:
return True
return False # 否则返回False这种模式让函数的逻辑路径更清晰,避免了深层嵌套的
if/else
理解Python中变量的作用域(Scope)是编写可靠函数的基础,而闭包(Closure)则是在此基础上更高级且强大的概念。
作用域(Scope): Python中的作用域遵循LEGB原则:
len
一个经典的例子:
x = "全局变量" # Global
def outer_function():
y = "外部函数的局部变量" # Enclosing
def inner_function():
z = "内部函数的局部变量" # Local
print(x) # 访问全局变量
print(y) # 访问外部函数的局部变量
print(z) # 访问内部函数的局部变量
inner_function()
# print(z) # 错误:z不在outer_function的作用域内
outer_function()
# print(y) # 错误:y不在全局作用域内这里有个常见的陷阱,如果你在函数内部尝试修改一个全局变量,Python会默认创建一个同名的局部变量,而不是修改全局变量。如果你真的想修改全局变量,需要使用
global
count = 0
def increment_bad():
count = 1 # 这是一个新的局部变量,不是修改全局的count
print(f"局部count: {count}")
def increment_good():
global count # 声明要修改的是全局变量
count += 1
print(f"全局count: {count}")
increment_bad() # 输出:局部count: 1
print(f"全局count(未变):{count}") # 输出:全局count(未变):0
increment_good() # 输出:全局count: 1
print(f"全局count(已变):{count}") # 输出:全局count(已变):1对于嵌套函数,如果你想在内层函数修改外层函数的局部变量,需要使用
nonlocal
闭包(Closure): 当一个内层函数引用了外层函数的局部变量,并且外层函数已经执行完毕,但内层函数仍然可以访问和操作那些变量时,我们就说这个内层函数形成了一个闭包。 闭包的核心在于:函数及其创建时所处的环境(即它能访问的非全局变量)的组合。
def make_multiplier(x):
def multiplier(y):
return x * y # multiplier 引用了外层函数的 x
return multiplier # 返回内层函数
# 创建两个不同的乘法器
times_3 = make_multiplier(3)
times_5 = make_multiplier(5)
print(times_3(10)) # 输出:30 (x=3, y=10)
print(times_5(10)) # 输出:50 (x=5, y=10)在这个例子中,
make_multiplier
x
multiplier
x
x
multiplier
闭包在很多场景下都非常有用,比如:
我个人觉得,闭包是Python函数式编程的一个重要基石,它让代码更具表达力和灵活性。理解了作用域和闭包,你就能更好地掌握Python的函数,并写出更高级、更优雅的代码。
以上就是python中如何定义和调用函数_Python函数定义与调用基础的详细内容,更多请关注php中文网其它相关文章!
python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号