【100天精通python】Day10:python 基础_函数的创建和调用,参数传递,返回值,变量作用域以及匿名函数

简介: 【100天精通python】Day10:python 基础_函数的创建和调用,参数传递,返回值,变量作用域以及匿名函数

63557cdeff30463b9934e90e19955c0c.png

        Python函数是一组可重复使用的代码块,用于执行特定的任务。函数能够接收输入参数并返回一个结果。

1. 函数的创建和调用

1.1 函数的创建

       在Python中,创建函数的语法使用def关键字,后面跟着函数的名称、参数列表和冒号(:)。函数的代码块必须使用缩进来表示,通常是四个空格。函数可以有一个文档字符串(docstring)来描述函数的用途和功能。

以下是创建函数的语法示例:

def function_name(parameter1, parameter2, ...):
    """文档字符串(可选)"""
    # 函数代码块
    # ...
    # 可以使用 return 语句返回结果(可选)
    # return result
  • function_name是函数的名称,遵循Python的命名规则,通常是小写字母,用下划线分隔单词。
  • parameter1, parameter2, ...是函数的参数列表,用于接收输入数据。参数可以有多个,用逗号分隔。参数可以是必需的参数、默认参数、可变参数和关键字参数,具体可以根据需要选择。
  • 文档字符串是可选的,用于描述函数的用途和功能。它位于函数定义的第一行,可以通过help()函数来查看。
  • 函数代码块是函数的主体,包含函数的执行逻辑。代码块必须缩进,并且在函数内部使用相同的缩进级别。

函数可以使用return语句来返回结果,也可以没有返回值。当函数执行到return语句时,它将停止执行并返回结果给调用者。如果函数没有显式的return语句,它将默认返回None。

以下是一个简单的函数示例:

def add(a, b):
    """这个函数用于将两个数字相加并返回结果"""
    return a + b
# 调用函数并打印结果
result = add(5, 3)
print(result)  # 输出:8

1.2  调用函数

       调用函数是指在代码中使用函数来执行特定的操作。调用函数的语法是在函数名称后面加上括号,并将参数传递给函数(如果函数定义了参数)。

以下是调用函数的基本语法:

result = function_name(argument1, argument2, ...)
  • function_name是要调用的函数的名称。
  • argument1, argument2, ...是要传递给函数的参数值。

在调用函数时,传递的参数值必须与函数定义中的参数顺序一致。如果函数有多个参数,可以按照顺序依次传递参数值。如果函数有默认参数,可以选择不传递这些参数,函数将使用默认值。

以下是一个简单的函数调用示例:

def add_numbers(a, b):
    return a + b
result = add_numbers(10, 20)
print(result)  # 输出结果为 30

在这个例子中,我们定义了一个名为add_numbers的函数,它接收两个参数a和b,并将它们相加后返回结果。然后我们调用这个函数并传递参数值10和20,得到结果30并打印出来。

2 参数传递

2.1 传递方式

     在Python中,参数传递可以通过值传递和引用传递两种方式实现。这取决于传递的是不可变对象还是可变对象。

值传递(Pass by Value):

       当传递的是不可变对象(如整数、字符串、元组等),Python采用值传递方式。在值传递中,函数接收到的是实参的副本,对形参的修改不会影响到实参。

def modify_number(x):
    x = x + 1
number = 5
modify_number(number)
print(number)  # 输出 5,函数中对形参 x 的修改不影响原始变量 number

引用传递(Pass by Reference):

        当传递的是可变对象(如列表、字典等),Python采用引用传递方式。在引用传递中,函数接收到的是实参对象的引用,对形参的修改会影响到实参。

def modify_list(my_list):
    my_list.append(4)
my_list = [1, 2, 3]
modify_list(my_list)
print(my_list)  # 输出 [1, 2, 3, 4],函数中对形参 my_list 的修改影响原始列表对象

       需要注意的是,在引用传递中,如果在函数内部直接对形参进行赋值,则会断开与原始对象的引用,从而不会影响原始对象。

def modify_list(my_list):
    my_list = [7, 8, 9]  # 在函数内部对形参进行赋值,断开与原始对象的引用
    print(my_list)
my_list = [1, 2, 3]
modify_list(my_list)
print(my_list)  # 输出 [1, 2, 3],函数内部的赋值不影响原始列表对象

总结:Python中的参数传递方式取决于传递的对象是否可变。对于不可变对象,采用值传递方式;对于可变对象,采用引用传递方式。

2.2 形参和实参

形参(Formal Parameters):

       形参是函数定义时在函数名后面括号中定义的参数名称。形参在函数体内充当局部变量的角色,它们是函数用来接收外部传递的值的占位符。

在下面的例子中,x和y就是形参:

def add_numbers(x, y):
    sum = x + y
    return sum

实参(Actual Parameters):

       实参是函数调用时传递给函数的具体值。它们是真正的数据或对象,用来填充函数定义中的形参。在下面的例子中,3和5就是实参:

result = add_numbers(3, 5)

当我们调用函数时,将实参传递给函数,这些实参的值会被复制到对应的形参中,然后在函数体内使用。在函数调用结束后,函数的局部变量(即形参)的作用域也结束,它们的值不会影响函数外部的变量。

需要注意的是,在函数调用时,实参的个数和类型必须与函数定义中形参的个数和类型匹配,否则会导致错误。

2.3 位置参数

       位置参数(Positional Arguments): 位置参数是最常见的函数参数传递方式,它们按照函数定义时的顺序依次接收传递的实参。当调用函数时,实参的位置与形参的位置要一一对应。

def add_numbers(a, b):
    return a + b
result = add_numbers(3, 5)
print(result)  # 输出 8

2.4 关键字参数

       关键字参数(Keyword Arguments): 关键字参数是指在函数调用时,通过指定参数名来传递参数,从而不必按照位置依次传递。关键字参数可以让函数调用更加清晰和易读。

def print_info(name, age):
    print("Name:", name)
    print("Age:", age)
print_info(name="Alice", age=30)

2.5 可变参数

       可变参数是一种特殊的参数类型,可以接收不定数量的参数。在Python中,有两种类型的可变参数:

  • *args:用于接收任意数量的位置参数,表示一个元组(tuple)。
  • **kwargs:用于接收任意数量的关键字参数,表示一个字典(dict)。
def add_all_numbers(*args):
    total = 0
    for num in args:
        total += num
    return total
result = add_all_numbers(1, 2, 3, 4, 5)
print(result)  # 输出 15
def print_person_info(**kwargs):
    for key, value in kwargs.items():
        print(f"{key}: {value}")
print_person_info(name="Alice", age=30, city="New York")


注意:在函数定义时,位置参数、可变参数和关键字参数的顺序应该是:位置参数 -> *args -> **kwargs。例如:

def my_function(a, b, *args, **kwargs):
    # 函数体

以上的参数定义是合法的,而且是推荐的顺序。

2.6 为参数设置默认值

       在Python中,你可以为函数的参数设置默认值,这样在调用函数时,如果没有传递该参数的值,就会使用默认值。

       设置默认值的语法是在函数定义时使用等号(=)来为参数指定默认值。

def greet(name, greeting="Hello"):
    print(f"{greeting}, {name}!")
# 调用函数时未指定greeting参数,将使用默认值
greet("Alice")  # 输出:Hello, Alice!
# 也可以在调用函数时指定greeting参数的值
greet("Bob", "Hi")  # 输出:Hi, Bob!

注意事项:

  • 默认值参数要放在位置参数之后,不然会报错。
  • 默认值只在函数定义时绑定一次,即每次调用函数时,如果不传递对应的参数,则会使用之前绑定的默认值。

如果希望默认值参数在每次函数调用时都是新的对象,可以使用None作为默认值,并在函数体内根据需要处理。

def add_to_list(value, my_list=None):
    if my_list is None:
        my_list = []
    my_list.append(value)
    return my_list
# 第一次调用函数
result1 = add_to_list(1)
print(result1)  # 输出:[1]
# 第二次调用函数,不会影响之前的结果
result2 = add_to_list(2)
print(result2)  # 输出:[2]

3 返回值

       在Python中,函数可以通过return语句返回一个值给调用者。返回值是函数执行完毕后将要传递给调用者的数据。返回值可以是任意数据类型,包括整数、浮点数、字符串、列表、字典等。

       函数可以没有返回值,此时函数执行完毕后默认返回None。如果函数中没有return语句,或者return后面没有表达式,则函数返回None。

下面是一个示例函数,它接收两个参数并返回它们的和:

def add_numbers(a, b):
    sum = a + b
    return sum
result = add_numbers(3, 5)
print(result)  # 输出结果为 8,函数返回了参数3和5的和

4 变量的作用域

       在Python中,变量的作用域是指变量在程序中可以被访问的范围。Python中有三种类型的作用域:

4.1 局部变量

       变量在函数内部定义的时候,其作用域为函数的局部作用域,只能在函数内部被访问。

def my_function():
    x = 10  # 局部变量
    print(x)
my_function()  # 输出:10
print(x)  # 报错,x在函数外部不可访问

4.2 嵌套变量

       嵌套作用域是指在一个函数内部,有另一个函数定义的情况。内部函数可以访问外部函数中定义的变量。

def outer_function():
    y = 20  # 嵌套作用域变量
    def inner_function():
        print(y)
    inner_function()
outer_function()  # 输出:20

4.3 全局变量

       变量在函数外部定义的时候,其作用域为全局作用域,可以在整个程序中被访问。

global_variable = 30  # 全局变量
def my_function():
    print(global_variable)  # 可以在函数内部访问全局变量
my_function()  # 输出:30
print(global_variable)  # 输出:30

其他:

在函数内部,可以使用global关键字来声明一个变量为全局变量,这样在函数内部对该变量的修改也会影响到全局作用域。如下:

x = 50  # 全局变量
def update_global():
    global x
    x = x + 1
update_global()
print(x)  # 输出:51

注意:在函数内部,如果使用=来为变量赋值,会默认将变量视为局部变量,如果想要修改全局变量,必须使用global关键字来声明。否则,函数内部会创建一个新的局部变量,而不会影响到全局变量。

5 匿名函数(Lambda函数)

       在Python中,匿名函数也称为Lambda函数,是一种特殊类型的函数,它允许你创建简单的、一行的函数,通常用于定义简单的功能,而不需要为它们命名。

Lambda函数的语法如下:

lambda arguments: expression

其中,arguments是参数列表,可以是任意个数的参数,但只能有一个表达式。Lambda函数的执行结果就是这个表达式的结果。

下面是一个简单的Lambda函数示例:

add = lambda x, y: x + y
result = add(3, 5)
print(result)  # 输出:8

在这个例子中,我们定义了一个Lambda函数 add,它接受两个参数 x 和 y,并返回它们的和。

Lambda函数通常用于需要一个简单的函数,而不想定义一个完整的函数的情况。例如,在排序列表时,可以使用Lambda函数来指定排序的关键字:

fruits = ['apple', 'orange', 'banana', 'cherry']
fruits.sort(key=lambda x: len(x))
print(fruits)  # 输出:['apple', 'cherry', 'orange', 'banana']

在这个例子中,我们使用Lambda函数作为sort()方法的key参数,用来指定排序的关键字为字符串的长度。这样,fruits列表将按字符串长度从短到长进行排序。

0535ae41ad704fa9bef2f4480b88b335.png

目录
相关文章
|
2天前
|
开发者 Python
Python入门:8.Python中的函数
### 引言 在编写程序时,函数是一种强大的工具。它们可以将代码逻辑模块化,减少重复代码的编写,并提高程序的可读性和可维护性。无论是初学者还是资深开发者,深入理解函数的使用和设计都是编写高质量代码的基础。本文将从基础概念开始,逐步讲解 Python 中的函数及其高级特性。
Python入门:8.Python中的函数
|
1月前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
16 0
作用域|Python从入门到精通:高阶篇之九
本节重点介绍了python的作用域,全局作用域和函数作用域。
作用域|Python从入门到精通:高阶篇之九
|
2月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
2月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
2月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
126 80
|
24天前
|
存储 缓存 Java
Python高性能编程:五种核心优化技术的原理与Python代码
Python在高性能应用场景中常因执行速度不及C、C++等编译型语言而受质疑,但通过合理利用标准库的优化特性,如`__slots__`机制、列表推导式、`@lru_cache`装饰器和生成器等,可以显著提升代码效率。本文详细介绍了这些实用的性能优化技术,帮助开发者在不牺牲代码质量的前提下提高程序性能。实验数据表明,这些优化方法能在内存使用和计算效率方面带来显著改进,适用于大规模数据处理、递归计算等场景。
58 5
Python高性能编程:五种核心优化技术的原理与Python代码
|
3月前
|
存储 索引 Python
Python编程数据结构的深入理解
深入理解 Python 中的数据结构是提高编程能力的重要途径。通过合理选择和使用数据结构,可以提高程序的效率和质量
173 59
|
2月前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
53 14
|
2月前
|
分布式计算 大数据 数据处理
技术评测:MaxCompute MaxFrame——阿里云自研分布式计算框架的Python编程接口
随着大数据和人工智能技术的发展,数据处理的需求日益增长。阿里云推出的MaxCompute MaxFrame(简称“MaxFrame”)是一个专为Python开发者设计的分布式计算框架,它不仅支持Python编程接口,还能直接利用MaxCompute的云原生大数据计算资源和服务。本文将通过一系列最佳实践测评,探讨MaxFrame在分布式Pandas处理以及大语言模型数据处理场景中的表现,并分析其在实际工作中的应用潜力。
119 2

热门文章

最新文章