Python 函数(2)

2、函数

2.1、函数传递列表

将列表传递给函数后,函数就能直接访问其内容。

下列为一个实例:将一个名字列表传递给一个名为greet_users()的函数,这个函数将会向列表中的每一个元素执行相应的信息。

python 复制代码
def greet_users(name):
    for name in names:
        msg=f"Helo,{name.title()}!"
        print(msg)
names=['hannah','ty','margot']
greet_users(names)

我们将 greet_users()定义成接受一个名字的列表,并将其赋给形参names。这个函数遍历收到的列表,并对其中的每个元素打印一条信息。

2.1.1、在函数中修改列表

将列表传递给函数后,函数就可以对其进行修改了。在函数中对这个列表所做的任何修改都是永久的。

2.1.2、禁止函数修改列表

既要打印出执行操作后的列表,又要打印出原来的原始列表。为了解决这一问题,可向函数传递列表的副本而不是原来的列表。这样,函数所做的任何操作就都影响副本,而丝毫不影响原始列表。要将例表的副本传递给函数可以使用切片表示法[:]

2.2、传递任意数量的实参

有时不知函数需要接受多少个实参,好在Python允许函数从调用语句中收集任意数量的实参。

下面的函数只有一个形参*topp,不管调用语句提供了多少个实参,它都能将其收入囊中:

python 复制代码
def pizza(*topp):
    print(topp)
pizza('pepperoni')
pizza('mush','green peppers','extre')

形参名*topp中的星号让Python创建一个名为topp的元组,该元组包含函数收到的所有值。

**注:Python会将实参封装到一个元组中,即便函数值收到一个值也将它为元组看待。**所以下面的输出中的('pepperoni',)的后面有一个逗号:

不管函数收到多少个实参,这种语法都管用。

2.2.1、结合使用位置实参和任意数量的实参

要让函数接受不同类型的实参,必须在函数定义中将接受任意数量实参的形参放在最后。Python先匹配位置实参和关键词实参,再将剩下的实参收集到最后一个形参中。

例如下:

python 复制代码
def pizza(size,*topp):
    print(size)
    for topps in topp:
        print(f"-{topps}")

pizza(11,'pepperoni')
pizza(21,'mush','green peppers','extre')

pizza有两个形参,基于函数的定义,Python收到的第一个值赋给第一个形参size,将其他的所有的值都存储在元组topp中。调用两次函数,第一个值都是赋给第一个形参,余下的都存储在元组:

注:经常会看到通用形参名*args,它也这样收集任意数量的位置实参。

2.2.2、使用任意数量的关键字实参

当需要接受任意函数数量的实参,但预先不知道传递给函数的会是什么样的信息。在这种情况喜爱,可将函数编写成能够接受任意数量的键值对------调用语句提供多少就接受多少。

下列实例:

python 复制代码
def profile(first,last,**usef_info):
    usef_info['first_name']=first
    usef_info['last_name']=last
    return usef_info
uprofile=profile('albert','einstein',
                 location='princeton',
                 field='physics')
print(uprofile)

profile()函数的定义要求提供名和姓,同是允许根据需要提供任意数值的名值对。形参**usef_info中的两个星号让Python创建一个名为usef_info的字典,该字典包含函数收到的其他名值对。

相关推荐
我有一只臭臭18 小时前
ES5 和 ES6 类的实现
前端·javascript·es6
excel18 小时前
Three.js 实现高分辨率地球边界可视化
前端
2401_8454174518 小时前
set和map
java·开发语言
LaoZhangAI18 小时前
Google Gemini AI图片编辑完全指南:50+中英对照提示词与批量处理教程(2025年9月)
前端·后端
2301_8210465218 小时前
Python的深度学习
开发语言·javascript·ecmascript
用户114818678948418 小时前
从零搭建 Vue3 + Nest.js 实时通信项目:4 种方案(短轮询 / 长轮询 / SSE/WebSocket)
前端·后端
LaoZhangAI18 小时前
Google Gemini Nano与Banana AI完整部署指南:2025年轻量级AI解决方案
前端·后端
强盛小灵通专卖员18 小时前
闪电科创 SCI专业辅导
python·深度强化学习·研究生·ei会议·导师·sci期刊
用户114818678948418 小时前
基于 Webpack Module Federation 的 Vue 微前端实践
前端
怪可爱的地球人18 小时前
Pinia状态管理有哪些常用API?
前端