Python:核心知识点整理大全16-笔记

目录

 8.2.3 默认值

8.2.4 等效的函数调用

8.2.5 避免实参错误

8.3 返回值

8.3.1 返回简单值

formatted_name.py

8.3.2 让实参变成可选的

8.3.3 返回字典

往期快速传送门👆(在文章最后):


 8.2.3 默认值

编写函数时,可给每个形参指定默认值。在调用函数中给形参提供了实参时,Python将使用 指定的实参值;否则,将使用形参的默认值。因此,给形参指定默认值后,可在函数调用中省略 相应的实参。使用默认值可简化函数调用,还可清楚地指出函数的典型用法。

例如,如果你发现调用describe_pet()时,描述的大都是小狗,就可将形参animal_type的默 认值设置为'dog'。这样,调用describe_pet()来描述小狗时,就可不提供这种信息:

def describe_pet(pet_name, animal_type='dog'):
 """显示宠物的信息"""
 print("\nI have a " + animal_type + ".")
 print("My " + animal_type + "'s name is " + pet_name.title() + ".") 
describe_pet(pet_name='willie') 

这里修改了函数describe_pet()的定义,在其中给形参animal_type指定了默认值'dog'。这 样,调用这个函数时,如果没有给animal_type指定值,Python将把这个形参设置为'dog':

I have a dog.
My dog's name is Willie. 

请注意,在这个函数的定义中,修改了形参的排列顺序。由于给animal_type指定了默认值, 无需通过实参来指定动物类型,因此在函数调用中只包含一个实参——宠物的名字。然而,Python 依然将这个实参视为位置实参,因此如果函数调用中只包含宠物的名字,这个实参将关联到函数 定义中的第一个形参。这就是需要将pet_name放在形参列表开头的原因所在。 现在,使用这个函数的最简单的方式是,在函数调用中只提供小狗的名字:

describe_pet('willie') 

这个函数调用的输出与前一个示例相同。只提供了一个实参——'willie',这个实参将关联 到函数定义中的第一个形参——pet_name。由于没有给animal_type提供实参,因此Python使用其 默认值'dog'。

如果要描述的动物不是小狗,可使用类似于下面的函数调用:

describe_pet(pet_name='harry', animal_type='hamster')

由于显式地给animal_type提供了实参,因此Python将忽略这个形参的默认值。


注意 使用默认值时,在形参列表中必须先列出没有默认值的形参,再列出有默认值的实参。 这让Python依然能够正确地解读位置实参。


8.2.4 等效的函数调用

鉴于可混合使用位置实参、关键字实参和默认值,通常有多种等效的函数调用方式。请看下 面的函数describe_pets()的定义,其中给一个形参提供了默认值:

def describe_pet(pet_name, animal_type='dog'): 

基于这种定义,在任何情况下都必须给pet_name提供实参;指定该实参时可以使用位置方式, 也可以使用关键字方式。如果要描述的动物不是小狗,还必须在函数调用中给animal_type提供 实参;同样,指定该实参时可以使用位置方式,也可以使用关键字方式。 下面对这个函数的所有调用都可行:

# 一条名为Willie的小狗
describe_pet('willie')
describe_pet(pet_name='willie')
# 一只名为Harry的仓鼠
describe_pet('harry', 'hamster')
describe_pet(pet_name='harry', animal_type='hamster')
describe_pet(animal_type='hamster', pet_name='harry')

这些函数调用的输出与前面的示例相同。


注意 使用哪种调用方式无关紧要,只要函数调用能生成你希望的输出就行。使用对你来说最 容易理解的调用方式即可。


8.2.5 避免实参错误

等你开始使用函数后,如果遇到实参不匹配错误,不要大惊小怪。你提供的实参多于或少于 函数完成其工作所需的信息时,将出现实参不匹配错误。例如,如果调用函数describe_pet()时 没有指定任何实参,结果将如何呢?

def describe_pet(animal_type, pet_name):
 """显示宠物的信息"""
 print("\nI have a " + animal_type + ".")
 print("My " + animal_type + "'s name is " + pet_name.title() + ".")
describe_pet()

Python发现该函数调用缺少必要的信息,而traceback指出了这一点:

1 File "pets.py", line 6, in <module>
2 describe_pet()
3 TypeError: describe_pet() missing 2 required positional arguments: 'animal_
type' and 'pet_name' 

在1处,traceback指出了问题出在什么地方,让我们能够回过头去找出函数调用中的错误。 在2处,指出了导致问题的函数调用。在3处,traceback指出该函数调用少两个实参,并指出了 相应形参的名称。如果这个函数存储在一个独立的文件中,我们也许无需打开这个文件并查看函 数的代码,就能重新正确地编写函数调用。

Python读取函数的代码,并指出我们需要为哪些形参提供实参,这提供了极大的帮助。这也 是应该给变量和函数指定描述性名称的另一个原因;如果你这样做了,那么无论对于你,还是可 能使用你编写的代码的其他任何人来说,Python提供的错误消息都将更有帮助。 如果提供的实参太多,将出现类似的traceback,帮助你确保函数调用和函数定义匹配。

8.3 返回值

函数并非总是直接显示输出,相反,它可以处理一些数据,并返回一个或一组值。函数返回 的值被称为返回值。在函数中,可使用return语句将值返回到调用函数的代码行。返回值让你能 够将程序的大部分繁重工作移到函数中去完成,从而简化主程序。

8.3.1 返回简单值

下面来看一个函数,它接受名和姓并返回整洁的姓名:

formatted_name.py
1 def get_formatted_name(first_name, last_name):
"""返回整洁的姓名"""
2 full_name = first_name + ' ' + last_name
3 return full_name.title()
4 musician = get_formatted_name('jimi', 'hendrix')
print(musician) 

函数get_formatted_name()的定义通过形参接受名和姓(见1)。它将姓和名合而为一,在它 们之间加上一个空格,并将结果存储在变量full_name中(见2)。然后,将full_name的值转换为 首字母大写格式,并将结果返回到函数调用行(见3)。 调用返回值的函数时,需要提供一个变量,用于存储返回的值。在这里,将返回值存储在了 变量musician中(见4)。输出为整洁的姓名:

Jimi Hendrix 

我们原本只需编写下面的代码就可输出整洁的姓名,相比于此,前面做的工作好像太多了

print("Jimi Hendrix") 

但在需要分别存储大量名和姓的大型程序中,像get_formatted_name()这样的函数非常有用。 你分别存储名和姓,每当需要显示姓名时都调用这个函数。

8.3.2 让实参变成可选的

有时候,需要让实参变成可选的,这样使用函数的人就只需在必要时才提供额外的信息。可 使用默认值来让实参变成可选的。

例如,假设我们要扩展函数get_formatted_name(),使其还处理中间名。为此,可将其修改 成类似于下面这样:

def get_formatted_name(first_name, middle_name, last_name):
 """返回整洁的姓名"""
 full_name = first_name + ' ' + middle_name + ' ' + last_name
 return full_name.title()
musician = get_formatted_name('john', 'lee', 'hooker')
print(musician)

只要同时提供名、中间名和姓,这个函数就能正确地运行。它根据这三部分创建一个字符串, 在适当的地方加上空格,并将结果转换为首字母大写格式:

John Lee Hooker 

然而,并非所有的人都有中间名,但如果你调用这个函数时只提供了名和姓,它将不能正确 地运行。为让中间名变成可选的,可给实参middle_name指定一个默认值——空字符串,并在用 户没有提供中间名时不使用这个实参。为让get_formatted_name()在没有提供中间名时依然可行, 可给实参middle_name指定一个默认值——空字符串,并将其移到形参列表的末尾:

1 def get_formatted_name(first_name, last_name, middle_name=''):
 """返回整洁的姓名"""
2 if middle_name:
 full_name = first_name + ' ' + middle_name + ' ' + last_name
3 else:
 full_name = first_name + ' ' + last_name
 return full_name.title()
musician = get_formatted_name('jimi', 'hendrix')
print(musician)
4 musician = get_formatted_name('john', 'hooker', 'lee')
print(musician) 

在这个示例中,姓名是根据三个可能提供的部分创建的。由于人都有名和姓,因此在函数定 义中首先列出了这两个形参。中间名是可选的,因此在函数定义中最后列出该形参,并将其默认 值设置为空字符串(见1)。

在函数体中,我们检查是否提供了中间名。Python将非空字符串解读为True,因此如果函数 调用中提供了中间名,if middle_name将为True(见2)。如果提供了中间名,就将名、中间名和 姓合并为姓名,然后将其修改为首字母大写格式,并返回到函数调用行。在函数调用行,将返回 的值存储在变量musician中;然后将这个变量的值打印出来。如果没有提供中间名,middle_name 将为空字符串,导致if测试未通过,进而执行else代码块(见3):只使用名和姓来生成姓名, 并将设置好格式的姓名返回给函数调用行。在函数调用行,将返回的值存储在变量musician中; 然后将这个变量的值打印出来。

调用这个函数时,如果只想指定名和姓,调用起来将非常简单。如果还要指定中间名,就必 须确保它是最后一个实参,这样Python才能正确地将位置实参关联到形参(见4)。

这个修改后的版本适用于只有名和姓的人,也适用于还有中间名的人:

Jimi Hendrix
John Lee Hooker 

可选值让函数能够处理各种不同情形的同时,确保函数调用尽可能简单。

8.3.3 返回字典

函数可返回任何类型的值,包括列表和字典等较复杂的数据结构。例如,下面的函数接受姓 名的组成部分,并返回一个表示人的字典:

person.py

def build_person(first_name, last_name):
 """返回一个字典,其中包含有关一个人的信息"""
1 person = {'first': first_name, 'last': last_name}
2 return person
musician = build_person('jimi', 'hendrix')
3 print(musician) 

函数build_person()接受名和姓,并将这些值封装到字典中(见1)。存储first_name的值时, 使用的键为'first',而存储last_name的值时,使用的键为'last'。最后,返回表示人的整个字 典(见2)。在3处,打印这个返回的值,此时原来的两项文本信息存储在一个字典中:

{'first': 'jimi', 'last': 'hendrix'} 

这个函数接受简单的文本信息,将其放在一个更合适的数据结构中,让你不仅能打印这些信 息,还能以其他方式处理它们。当前,字符串'jimi'和'hendrix'被标记为名和姓。你可以轻松地 扩展这个函数,使其接受可选值,如中间名、年龄、职业或你要存储的其他任何信息。例如,下面的修改让你还能存储年龄:

def build_person(first_name, last_name, age=''):
 """返回一个字典,其中包含有关一个人的信息"""
 person = {'first': first_name, 'last': last_name}
 if age:
 person['age'] = age
 return person
musician = build_person('jimi', 'hendrix', age=27)
print(musician) 

在函数定义中,我们新增了一个可选形参age,并将其默认值设置为空字符串。如果函数调 用中包含这个形参的值,这个值将存储到字典中。在任何情况下,这个函数都会存储人的姓名, 但可对其进行修改,使其也存储有关人的其他信息。


Python:核心知识点整理大全12-笔记-CSDN博客

往期快速传送门👆(在文章最后):

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/240161.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Docker镜像构建:深入Dockerfile创建自定义镜像

Docker的强大之处在于其能够通过Dockerfile定义和构建自定义镜像&#xff0c;为应用提供独立、可移植的运行环境。在这篇博客文章中&#xff0c;将深入探讨Docker镜像构建的核心概念&#xff0c;通过更加丰富的示例代码&#xff0c;帮助大家全面理解和掌握构建自定义镜像的技术…

机器学习笔记 - 基于C# + .net framework 4.8的ONNX Runtime进行分类推理

该示例是从官方抄的,演示了如何使用 Onnx Runtime C# API 运行预训练的 ResNet50 v2 ONNX 模型。 我这里的环境基于.net framework 4.8的一个winform项目,主要依赖下面版本的相关库。 Microsoft.Bcl.Numerics.8.0.0 Microsoft.ML.OnnxRuntime.Gpu.1.16.3 SixLabors.ImageShar…

掌握iText:轻松处理PDF文档-高级篇-添加水印

前言 iText作为一个功能强大、灵活且广泛应用的PDF处理工具&#xff0c;在实际项目中发挥着重要作用。通过这些文章&#xff0c;读者可以深入了解如何利用iText进行PDF的创建、编辑、加密和提取文本等操作&#xff0c;为日常开发工作提供了宝贵的参考和指导。 掌握iText&…

并发编程-线程等待唤醒机制

目录 前言 ​编辑 线程等待和唤醒的方法 wait() 方法&#xff1a; notify() 方法&#xff1a; 注意事项和建议&#xff1a; 我的其他博客 前言 程等待唤醒机制是多线程编程中用于线程之间协调和通信的一种机制。在多线程环境中&#xff0c;有时候一个线程需要等待某个条件…

【大数据】Doris 架构

Doris 架构 Doris 的架构很简洁&#xff0c;只设 FE&#xff08;Frontend&#xff09;、BE&#xff08;Backend&#xff09;两种角色、两个进程&#xff0c;不依赖于外部组件&#xff0c;方便部署和运维&#xff0c;FE、BE 都可线性扩展。 ✅ Frontend&#xff08;FE&#xff0…

C++_类的定义和使用

目录 1、类的引用 1.1 类的成员函数 1.2 类成员函数的声明和定义 2、类的定义 2.1 类的访问限定&#xff08;封装&#xff09; 3、类重名问题 4、类的实例化 4.1 类的大小 5、隐含的this指针 5.1 空指针问题 结语&#xff1a; 前言&#xff1a; C的类跟c语言中的结…

Standoff 12 网络演习

在 11 月 21 日至 24 日于莫斯科举行的 "Standoff 12 "网络演习中&#xff0c;Positive Technologies 公司再现了其真实基础设施的一部分&#xff0c;包括软件开发、组装和交付的所有流程。安全研究人员能够在安全的环境中测试系统的安全性&#xff0c;并尝试将第三方…

GO闭包实现原理(汇编级讲解)

go语言闭包实现原理(汇编层解析) 1.起因 今天开始学习go语言,在学到go闭包时候,原本以为go闭包的实现方式就是类似于如下cpp lambda value通过值传递,mutable修饰可以让value可以修改,但是地址不可能一样value通过引用传递,但是在其他地方调用时,这个value局部变量早就释放,…

低多边形植物模型法线贴图

在线工具推荐&#xff1a; 3D数字孪生场景编辑器 - GLTF/GLB材质纹理编辑器 - 3D模型在线转换 - Three.js AI自动纹理开发包 - YOLO 虚幻合成数据生成器 - 三维模型预览图生成器 - 3D模型语义搜索引擎 当谈到游戏角色的3D模型风格时&#xff0c;有几种不同的风格&#xf…

深度学习在人体动作识别领域的应用:开源工具、数据集资源及趋动云GPU算力不可或缺

人体动作识别检测是一种通过使用计算机视觉和深度学习技术&#xff0c;对人体姿态和动作进行实时监测和分析的技术。该技术旨在从图像或视频中提取有关人体姿态、动作和行为的信息&#xff0c;以便更深入地识别和理解人的活动。 人体动作识别检测的基本步骤包括&#xff1a; 数…

web279(s2-001)

目前java小白一个&#xff0c;主要是学学别人的思路 进入题目&#xff0c;登录框一个 抓包也没发现什么东西 网上说是struts2框架 Struts2是用Java语言编写的一个基于MVC设计模式的Web应用框架 判断是不是基于struts2的一些方法&#xff1a; 1.通过页面回显的错误消息来判断…

MySQL一行记录是怎么存储的?

文章目录 MySQL 一行记录是怎么存储的&#xff1f;MySQL 的数据存放在哪个文件&#xff1f;表空间文件结构 InnoDB行格式有哪些Compact行格式varchar(n) 中 n 最大取值为多少&#xff1f;行溢出后&#xff0c;MySQL是怎么处理的&#xff1f; MySQL 一行记录是怎么存储的&#x…

IDEA 出现问题:git提交commit时Perform code analysis卡住解决方案

问题 git提交commit时Perform code analysis卡住很久 解决方案一 1、打开 IntelliJ IDEA&#xff0c;进入 File -> Settings&#xff08;或者使用快捷键 CtrlAltS&#xff09;。 2、在弹出的 Settings 窗口中&#xff0c;找到 Version Control -> Commit Dialog 选项…

Flink 有状态流式处理

传统批次处理方法 【1】持续收取数据&#xff08;kafka等&#xff09;&#xff0c;以window时间作为划分&#xff0c;划分一个一个的批次档案&#xff08;按照时间或者大小等&#xff09;&#xff1b; 【2】周期性执行批次运算&#xff08;Spark/Stom等&#xff09;&#xff1b…

机器学习---Adaboost算法

1. Adaboost算法介绍 Adaboost是一种迭代算法&#xff0c;其核心思想是针对同一个训练集训练不同的分类器&#xff08;弱分类器&#xff09;&#xff0c;然 后把这些弱分类器集合起来&#xff0c;构成一个更强的最终分类器&#xff08;强分类器&#xff09;。Adaboost算法本身…

CSS学习

CSS学习 1. 什么是css?2.css引入方式2.1 内嵌式2.2 外联式2.3 行内式2.4 引入方式特点 3. 基础选择器3.1 标签选择器3.2 类选择器3.3 id选择器3.4 通配符选择器 1. 什么是css? 2.css引入方式 2.1 内嵌式 2.2 外联式 提示: 需要在html文件中link目标样式表; 2.3 行内式 注意:…

【EventBus】EventBus源码浅析

二、EventBus源码解析 目录 1、EventBus的构造方法2、订阅者注册 2.1 订阅者方法的查找过程2.2 订阅者的注册过程1. subscriptionsByEventType 映射&#xff1a;2. typesBySubscriber 映射&#xff1a;2.3 总结订阅者的注册过程 3、事件的发送 3.1 使用Post提交事件3.2 使用p…

【STM32】DMA直接存储器存取

1 DMA简介 DMA&#xff08;Direct Memory Access&#xff09;直接存储器存取 可以直接访问STM32的存储器的&#xff0c;包括运行SRAM、程序存储器Flash和寄存器等等 DMA可以提供外设寄存器和存储器或者存储器和存储器之间的高速数据传输&#xff0c;无须CPU干预&#xff0c;节…

【lombok】从easyExcel read不到值到cglib @Accessors(chain = true)隐藏的大坑

背景: 在一次使用easyExcel.read 读取excel时&#xff0c;发现实体类字段没有值&#xff0c;在反复测试后&#xff0c;发现去掉Accessors(chain true)就正常了&#xff0c;为了验证原因&#xff0c;进行了一次代码跟踪 由于调用链路特别长&#xff0c;只列举出部分代码&#x…

二蛋赠书十一期:《TypeScript入门与区块链项目实战》

前言 大家好&#xff01;我是二蛋&#xff0c;一个热爱技术、乐于分享的工程师。在过去的几年里&#xff0c;我一直通过各种渠道与大家分享技术知识和经验。我深知&#xff0c;每一位技术人员都对自己的技能提升和职业发展有着热切的期待。因此&#xff0c;我非常感激大家一直…