关于“Python”的核心知识点整理大全12

目录

6.3.3 按顺序遍历字典中的所有键

6.3.4 遍历字典中的所有值

6.4 嵌套

6.4.1 字典列表

aliens.py

6.4.2 在字典中存储列表

pizza.py

favorite_languages.py

注意

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


6.3.3 按顺序遍历字典中的所有键

字典总是明确地记录键和值之间的关联关系,但获取字典的元素时,获取顺序是不可预测的。 这不是问题,因为通常你想要的只是获取与键相关联的正确的值。

要以特定的顺序返回元素,一种办法是在for循环中对返回的键进行排序。为此,可使用函 数sorted()来获得按特定顺序排列的键列表的副本:

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python',}
for name in sorted(favorite_languages.keys()):print(name.title() + ", thank you for taking the poll.")

这条for语句类似于其他for语句,但对方法dictionary.keys()的结果调用了函数sorted()。 这让Python列出字典中的所有键,并在遍历前对这个列表进行排序。输出表明,按顺序显示了所 有被调查者的名字:

Edward, thank you for taking the poll.
Jen, thank you for taking the poll.
Phil, thank you for taking the poll.
Sarah, thank you for taking the poll.

6.3.4 遍历字典中的所有值

如果你感兴趣的主要是字典包含的值,可使用方法values(),它返回一个值列表,而不包含 任何键。例如,如果我们想获得一个这样的列表,即其中只包含被调查者选择的各种语言,而不 包含被调查者的名字,可以这样做:

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python', }
print("The following languages have been mentioned:")
for language in favorite_languages.values():print(language.title()) 

这条for语句提取字典中的每个值,并将它们依次存储到变量language中。通过打印这些值, 就获得了一个列表,其中包含被调查者选择的各种语言:

The following languages have been mentioned:
Python
C
Python
Ruby

这种做法提取字典中所有的值,而没有考虑是否重复。涉及的值很少时,这也许不是问题, 但如果被调查者很多,最终的列表可能包含大量的重复项。为剔除重复项,可使用集合(set)。 集合类似于列表,但每个元素都必须是独一无二的:

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python',}
print("The following languages have been mentioned:")
1 for language in set(favorite_languages.values()):print(language.title()) 

通过对包含重复元素的列表调用set(),可让Python找出列表中独一无二的元素,并使用这 些元素来创建一个集合。在1处,我们使用了set()来提取favorite_languages.values()中不同的 语言。

结果是一个不重复的列表,其中列出了被调查者提及的所有语言:

The following languages have been mentioned:
Python
C
Ruby 

随着你更深入地学习Python,经常会发现它内置的功能可帮助你以希望的方式处理数据。

6.4 嵌套

有时候,需要将一系列字典存储在列表中,或将列表作为值存储在字典中,这称为嵌套。你 可以在列表中嵌套字典、在字典中嵌套列表甚至在字典中嵌套字典。正如下面的示例将演示的, 嵌套是一项强大的功能。

6.4.1 字典列表

字典alien_0包含一个外星人的各种信息,但无法存储第二个外星人的信息,更别说屏幕上 全部外星人的信息了。如何管理成群结队的外星人呢?一种办法是创建一个外星人列表,其中每 个外星人都是一个字典,包含有关该外星人的各种信息。例如,下面的代码创建一个包含三个外 星人的列表:

aliens.py

alien_0 = {'color': 'green', 'points': 5}
alien_1 = {'color': 'yellow', 'points': 10}
alien_2 = {'color': 'red', 'points': 15}
1 aliens = [alien_0, alien_1, alien_2]
for alien in aliens:print(alien) 

我们首先创建了三个字典,其中每个字典都表示一个外星人。在处,我们将这些字典都放 到一个名为aliens的列表中。最后,我们遍历这个列表,并将每个外星人都打印出来:

{'color': 'green', 'points': 5}
{'color': 'yellow', 'points': 10}
{'color': 'red', 'points': 15} 

更符合现实的情形是,外星人不止三个,且每个外星人都是使用代码自动生成的。在下面的 示例中,我们使用range()生成了30个外星人:

# 创建一个用于存储外星人的空列表
aliens = []
# 创建30个绿色的外星人
1 for alien_number in range(30):
2 new_alien = {'color': 'green', 'points': 5, 'speed': 'slow'}
3 aliens.append(new_alien)
# 显示前五个外星人
4 for alien in aliens[:5]:print(alien)
print("...")
# 显示创建了多少个外星人
5 print("Total number of aliens: " + str(len(aliens)))

在这个示例中,首先创建了一个空列表,用于存储接下来将创建的所有外星人。在1处, range()返回一系列数字,其唯一的用途是告诉Python我们要重复这个循环多少次。每次执行这个 循环时,都创建一个外星人(见2),并将其附加到列表aliens末尾(见3)。在4处,使用 一个切片来打印前五个外星人;在5处,打印列表的长度,以证明确实创建了30个外星人:

{'speed': 'slow', 'color': 'green', 'points': 5}
{'speed': 'slow', 'color': 'green', 'points': 5}
{'speed': 'slow', 'color': 'green', 'points': 5}
{'speed': 'slow', 'color': 'green', 'points': 5}
{'speed': 'slow', 'color': 'green', 'points': 5}
...
Total number of aliens: 30

这些外星人都具有相同的特征,但在Python看来,每个外星人都是独立的,这让我们能够独 立地修改每个外星人。

在什么情况下需要处理成群结队的外星人呢?想象一下,可能随着游戏的进行,有些外星人 会变色且移动速度会加快。必要时,我们可以使用for循环和if语句来修改某些外星人的颜色。 例如,要将前三个外星人修改为黄色的、速度为中等且值10个点,可以这样做:

# 创建一个用于存储外星人的空列表
aliens = []
# 创建30个绿色的外星人
for alien_number in range (0,30):new_alien = {'color': 'green', 'points': 5, 'speed': 'slow'}aliens.append(new_alien)
for alien in aliens[0:3]:if alien['color'] == 'green':alien['color'] = 'yellow'alien['speed'] = 'medium'alien['points'] = 10
# 显示前五个外星人
for alien in aliens[0:5]:print(alien)
print("...") 

鉴于我们要修改前三个外星人,需要遍历一个只包含这些外星人的切片。当前,所有外星人 都是绿色的,但情况并非总是如此,因此我们编写了一条if语句来确保只修改绿色外星人。如果 外星人是绿色的,我们就将其颜色改为'yellow',将其速度改为'medium',并将其点数改为10, 如下面的输出所示:

{'speed': 'medium', 'color': 'yellow', 'points': 10}
{'speed': 'medium', 'color': 'yellow', 'points': 10}
{'speed': 'medium', 'color': 'yellow', 'points': 10}
{'speed': 'slow', 'color': 'green', 'points': 5}
{'speed': 'slow', 'color': 'green', 'points': 5}
... 

你可以进一步扩展这个循环,在其中添加一个elif代码块,将黄色外星人改为移动速度快且 值15个点的红色外星人,如下所示(这里只列出了循环,而没有列出整个程序):

for alien in aliens[0:3]:if alien['color'] == 'green':alien['color'] = 'yellow'alien['speed'] = 'medium'alien['points'] = 10elif alien['color'] == 'yellow':alien['color'] = 'red'alien['speed'] = 'fast'alien['points'] = 15 

经常需要在列表中包含大量的字典,而其中每个字典都包含特定对象的众多信息。例如,你 可能需要为网站的每个用户创建一个字典(就像6.3.1节的user.py中那样),并将这些字典存储在 一个名为users的列表中。在这个列表中,所有字典的结构都相同,因此你可以遍历这个列表, 并以相同的方式处理其中的每个字典。

6.4.2 在字典中存储列表

有时候,需要将列表存储在字典中,而不是将字典存储在列表中。例如,你如何描述顾客点的比萨呢?如果使用列表,只能存储要添加的比萨配料;但如果使用字典,就不仅可在其中包含 配料列表,还可包含其他有关比萨的描述。 在下面的示例中,存储了比萨的两方面信息:外皮类型和配料列表。其中的配料列表是一个 与键'toppings'相关联的值。要访问该列表,我们使用字典名和键'toppings',就像访问字典中 的其他值一样。这将返回一个配料列表,而不是单个值:

pizza.py

# 存储所点比萨的信息
1 pizza = {'crust': 'thick','toppings': ['mushrooms', 'extra cheese'],}
# 概述所点的比萨
2 print("You ordered a " + pizza['crust'] + "-crust pizza " +"with the following toppings:")
3 for topping in pizza['toppings']:print("\t" + topping) 

我们首先创建了一个字典,其中存储了有关顾客所点比萨的信息(见1)。在这个字典中, 一个键是'crust',与之相关联的值是字符串'thick';下一个键是'toppings',与之相关联的值 是一个列表,其中存储了顾客要求添加的所有配料。制作前我们概述了顾客所点的比萨(见2)。 为打印配料,我们编写了一个for循环(见3)。为访问配料列表,我们使用了键'toppings',这 样Python将从字典中提取配料列表。

下面的输出概述了要制作的比萨:

You ordered a thick-crust pizza with the following toppings:mushroomsextra cheese

每当需要在字典中将一个键关联到多个值时,都可以在字典中嵌套一个列表。在本章前面有 关喜欢的编程语言的示例中,如果将每个人的回答都存储在一个列表中,被调查者就可选择多种 喜欢的语言。在这种情况下,当我们遍历字典时,与每个被调查者相关联的都是一个语言列表, 而不是一种语言;因此,在遍历该字典的for循环中,我们需要再使用一个for循环来遍历与被调 查者相关联的语言列表:

favorite_languages.py

1 favorite_languages = {'jen': ['python', 'ruby'],'sarah': ['c'],'edward': ['ruby', 'go'],'phil': ['python', 'haskell'],}
2 for name, languages in favorite_languages.items():print("\n" + name.title() + "'s favorite languages are:")
3 for language in languages:print("\t" + language.title()) 

正如你看到的,现在与每个名字相关联的值都是一个列表(见1)。请注意,有些人喜欢的 语言只有一种,而有些人有多种。遍历字典时(见2),我们使用了变量languages来依次存储字 典中的每个值,因为我们知道这些值都是列表。在遍历字典的主循环中,我们又使用了一个for 循环来遍历每个人喜欢的语言列表(见3)。现在,每个人想列出多少种喜欢的语言都可以:

Jen's favorite languages are:PythonRuby
Sarah's favorite languages are:C
Phil's favorite languages are:PythonHaskell
Edward's favorite languages are:RubyGo 

为进一步改进这个程序,可在遍历字典的for循环开头添加一条if语句,通过查看len (languages)的值来确定当前的被调查者喜欢的语言是否有多种。如果他喜欢的语言有多种,就 像以前一样显示输出;如果只有一种,就相应修改输出的措辞,如显示Sarah's favorite language is C。


注意

列表和字典的嵌套层级不应太多。如果嵌套层级比前面的示例多得多,很可能有更简单 的解决问题的方案。


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

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

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

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

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

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

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

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

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

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

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

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VR全景技术对房产行业有什么好处,如何帮助展示户型

引言: 随着科技的飞速发展,VR全景技术逐渐走入我们的生活,为我们带来了前所未有的沉浸式体验。在房产行业,VR全景技术正逐渐改变传统的户型和样板间展示方式,为购房者带来更为直观、真实的购房体验。 一、VR全景技术在…

Docker多平台安装与配置指南

Docker的流行使得它成为开发者和运维人员不可或缺的工具。在本文中,将深入探讨如何在不同平台上安装和配置Docker,旨在为大家提供详尽的指南,确保他们能够顺利地使用这一强大的容器化工具。 Docker基础概念回顾 Docker利用容器技术&#xf…

回溯热门问题

关卡名 回溯热门问题 我会了✔️ 内容 1.组合总和问题 ✔️ 2.分割回文串问题 ✔️ 3.子集问题 ✔️ 4.排列问题 ✔️ 5.字母全排列问题 ✔️ 6.单词搜索 ✔️ 1. 组合总和问题 LeetCode39题目要求:给你一个无重复元素的整数数组candidates和一个目标整数 ta…

leetcode做题笔记2132. 用邮票贴满网格图

给你一个 m x n 的二进制矩阵 grid ,每个格子要么为 0 (空)要么为 1 (被占据)。 给你邮票的尺寸为 stampHeight x stampWidth 。我们想将邮票贴进二进制矩阵中,且满足以下 限制 和 要求 : 覆盖…

最快的排序算法TimSort还能更快吗

关于TimSort排序算法,请看这篇:另一位博主的博客 本文主要讨论让TimSort更快的方法。 已经产生了许多run,它们的长度是:4 6 2 5 7 用类似于霍夫曼编码的方法,找出最小的两项,相加。这里是4 2&#xff0c…

MATLAB 最小二乘直线拟合方法二 (36)

MATLAB 最小二乘直线拟合方法二 (36) 一、算法介绍二、算法实现1.代码2.结果一、算法介绍 这里介绍另一种拟合直线点云的方法,更为简单方便,结果与前者一致,主要内容直接复制代码使用即可,原理简单看代码即可,下面是具体的实现和拟合结果展示 二、算法实现 1.代码 代…

对Spring源码的学习:基于XML文件配置的开发流程

目录 BeanFactory开发流程 ApplicationContext BeanFactory与ApplicationContext对比 基于XML方式的Bean的配置 自动装配 BeanFactory开发流程 这里的第三方指的是Spring提供的BeanFactory,Spring启动时会初始化BeanFactory,然后读取配置清单&#…

2021实战面试

1、Rem , em , px , % , vw 之间的区别 PX: px像素(Pixel)。相对长度单位。像素px是相对于显示器屏幕分辨率而言的。 em: 1,子元素字体大小的em是相对于父元素字体大小 2,元素的width/height/padding/margin用em的话是相对于该元素的font-size rem:1rem是…

智能优化算法应用:基于象群算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用:基于象群算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于象群算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.象群算法4.实验参数设定5.算法结果6.参考文献7.MA…

仿windows12网盘,私有云盘部署教程,支持多种网盘

仿windows12网盘,私有云盘部署教程,支持多种网盘 资源宝分享:www.httple.net 视频教程:https://www.bilibili.com/video/BV1m64y1G7Bq/ 宝塔部署方式: 1.验证是否安装jdk,没有安装请看安装教程 推荐安装jdk8(注意您…

SAP ABAP 面试题交流

1.列举AT事件并说明其作用,AT事件中的工作区有何不同? AT FIRST 循环loop中执行第一条数据 AT LAST 循环loop中执行最后一条数据 AT NEW 循环loop中指定字段(包含指定字段)记录与上一条记录不一致数据执行 AT END OF 循环loo…

Visual Studio调试技巧合集

Visual Studio调试技巧合集 1 如何同一个项目运行不同main文件? 1 如何同一个项目运行不同main文件? (1)移动鼠标到需要关掉调试的文件,点击右键属性–常规–从生成中排除–是–确定,即显示“-”号排除&am…

Python自动化测试系列[v1.0.0][多种数据驱动实现附源码]

前情提要 请确保已经熟练掌握元素定位的常用方法及基本支持,请参考Python自动化测试系列[v1.0.0][元素定位] 数据驱动测试是自动化测试中一种重要的设计模式,这种设计模式可以将测试数据和测试代码分开,实现数据与代码解耦,与此同…

变量与方法面试题

char 型变量中能不能存储一个中文汉字,为什么? char 类型可以存储一个中文汉字,因为 Java 中使用的编码是 Unicode(不选择任何特定的编码,直接使用字符在字符集中的编号,这是统一的唯一方法)&a…

Python FuckIt模块:代码的“不死鸟”

更多资料获取 📚 个人网站:ipengtao.com 在编程世界中,每个开发者都曾遇到过代码中的错误,有时这些错误可能让人崩溃。但是,有一天,听说了一个叫做"FuckIt"的模块,它声称可以帮助摆脱…

【PIE-Engine 数据资源】全球海面温度产品

文章目录 一、 简介二、描述三、波段四、示例代码参考资料 一、 简介 数据名称全球海面温度产品时间范围2002年- 2018年空间范围全球数据来源毛克彪教授团队代码片段var images pie.lmageCollection(“CAAS/SSTG”) 二、描述 全球海面温度产品是 2002-2019 年的全球海面温度…

ES中根据主键_id查询记录

一、需求 es中_type:_doc,想要根据主键_id查询记录 二、实现 复合查询中使用语句查询http://192.168.1.1/_doc/1

Mybatis的foreach标签的使用以及参数的含义

Mybatis的foreach标签的使用以及参数的含义 语法格式: 属性说明: collection属性的注意点:

node js 递归生成vue文件目录

目录 什么是 fs 文件系统模块 fs.existsSync方法 方法说明: 语法: 向指定的文件中写入内容 writeFile fs.writeFile() 的语法格式 fs.writeFile() 的示例代码 判断文件是否写入成功 fs.mkdir 创建目录 目录已存在,重复创建 创建的目…

Python:Anaconda

简介 Anaconda是一个流行的Python发行版,专为科学计算和数据分析而设计。它包含了Python语言、Jupyter Notebook以及用于科学计算的众多包,如NumPy、Pandas、Matplotlib等。 Anaconda的特点是开箱即用,用户无需单独安装这些包,极…