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

目录

​编辑

6.2.4 修改字典中的值

 6.2.5 删除键—值对

注意 删除的键—值对永远消失了。

 6.2.6 由类似对象组成的字典

6.3 遍历字典

6.3.1 遍历所有的键—值对

6.3.2 遍历字典中的所有键

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


6.2.4 修改字典中的值

要修改字典中的值,可依次指定字典名、用方括号括起的键以及与该键相关联的新值。例如, 假设随着游戏的进行,需要将一个外星人从绿色改为黄色:

alien_0 = {'color': 'green'}
print("The alien is " + alien_0['color'] + ".")
alien_0['color'] = 'yellow'
print("The alien is now " + alien_0['color'] + ".")

我们首先定义了一个表示外星人alien_0的字典,其中只包含这个外星人的颜色。接下 来,我们将与键'color'相关联的值改为'yellow'。输出表明,这个外星人确实从绿色变成 了黄色:

The alien is green.
The alien is now yellow.

来看一个更有趣的例子:对一个能够以不同速度移动的外星人的位置进行跟踪。为此,我们 将存储该外星人的当前速度,并据此确定该外星人将向右移动多远:

alien_0 = {'x_position': 0, 'y_position': 25, 'speed': 'medium'}
print("Original x-position: " + str(alien_0['x_position']))
# 向右移动外星人
# 据外星人当前速度决定将其移动多远
1 if alien_0['speed'] == 'slow':x_increment = 1
elif alien_0['speed'] == 'medium':x_increment = 2
else:# 这个外星人的速度一定很快x_increment = 3
# 新位置等于老位置加上增量
2 alien_0['x_position'] = alien_0['x_position'] + x_increment
print("New x-position: " + str(alien_0['x_position']))

我们首先定义了一个外星人,其中包含初始的x坐标和y坐标,还有速度'medium'。出于简化 考虑,我们省略了颜色和点数,但即便包含这些键1 值对,这个示例的工作原理也不会有任何变 化。我们还打印了x_position的初始值,旨在让用户知道这个外星人向右移动了多远。 在处,使用了一个if-elif-else结构来确定外星人应向右移动多远,并将这个值存储在变 量x_increment中。如果外星人的速度为'slow',它将向右移动一个单位;如果速度为'medium', 将向右移动两个单位;如果为'fast',将向右移动三个单位。确定移动量后,将其与x_position 的当前值相加(见2 ),再将结果关联到字典中的键x_position。 由于这是一个速度中等的外星人,因此其位置将向右移动两个单位:

Original x-position: 0
New x-position: 2 

这种技术很棒:通过修改外星人字典中的值,可改变外星人的行为。例如,要将这个速度中 等的外星人变成速度很快的外星人,可添加如下代码行:

alien_0['speed'] = fast

这样,再次运行这些代码时,其中的if-elif-else结构将把一个更大的值赋给变量 x_increment。

 6.2.5 删除键—值对

对于字典中不再需要的信息,可使用del语句将相应的键—值对彻底删除。使用del语句时, 必须指定字典名和要删除的键。 例如,下面的代码从字典alien_0中删除键'points'及其值:

alien_0 = {'color': 'green', 'points': 5}
print(alien_0)
1 del alien_0['points']
print(alien_0)

1 处的代码行让Python将键'points'从字典alien_0中删除,同时删除与这个键相关联的值。 输出表明,键'points'及其值5已从字典中删除,但其他键—值对未受影响:

{'color': 'green', 'points': 5}
{'color': 'green'}

注意 删除的键—值对永远消失了。

 6.2.6 由类似对象组成的字典

在前面的示例中,字典存储的是一个对象(游戏中的一个外星人)的多种信息,但你也可以 使用字典来存储众多对象的同一种信息。例如,假设你要调查很多人,询问他们最喜欢的编程语 言,可使用一个字典来存储这种简单调查的结果,如下所示:

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python',} 

正如你看到的,我们将一个较大的字典放在了多行中。其中每个键都是一个被调查者的名字, 而每个值都是被调查者喜欢的语言。确定需要使用多行来定义字典时,在输入左花括号后按回车 键,再在下一行缩进四个空格,指定第一个键—值对,并在它后面加上一个逗号。此后你再次按 回车键时,文本编辑器将自动缩进后续键—值对,且缩进量与第一个键—值对相同。

定义好字典后,在最后一个键—值对的下一行添加一个右花括号,并缩进四个空格,使其与 字典中的键对齐。另外一种不错的做法是在最后一个键—值对后面也加上逗号,为以后在下一行 添加键—值对做好准备。


注意 对于较长的列表和字典,大多数编辑器都有以类似方式设置其格式的功能。对于较长的 字典,还有其他一些可行的格式设置方式,因此在你的编辑器或其他源代码中,你可能 会看到稍微不同的格式设置方式。


给定被调查者的名字,可使用这个字典轻松地获悉他喜欢的语言:

favorite_languages.py

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python',}
1 print("Sarah's favorite language is " +
2 favorite_languages['sarah'].title() +
3 ".")

为获悉Sarah喜欢的语言,我们使用如下代码:

favorite_languages['sarah']

在print语句中,我们使用了这种语法(见2);输出指出了Sarah喜欢的语言:

Sarah's favorite language is C. 

这个示例还演示了如何将较长的print语句分成多行。单词print比大多数字典名都短,因此 让输出的第一部分紧跟在左括号后面是合理的(见1)。请选择在合适的地方拆分要打印的内容, 并在第一行末尾(见)加上一个拼接运算符(+)。按回车键进入print语句的后续各行,并使 用Tab键将它们对齐并缩进一级。指定要打印的所有内容后,在print语句的最后一行末尾加上右 括号(见3)。

6.3 遍历字典


一个Python字典可能只包含几个键—值对,也可能包含数百万个键—值对。鉴于字典可能包含 大量的数据,Python支持对字典遍历。字典可用于以各种方式存储信息,因此有多种遍历字典的 方式:可遍历字典的所有键—值对、键或值。

6.3.1 遍历所有的键—值对

探索各种遍历方法前,先来看一个新字典,它用于存储有关网站用户的信息。下面的字典存 储一名用户的用户名、名和姓:

user_0 = {'username': 'efermi','first': 'enrico','last': 'fermi',} 

利用本章前面介绍过的知识,可访问user_0的任何一项信息,但如果要获悉该用户字典中的 所有信息,该怎么办呢?可以使用一个for循环来遍历这个字典:

user.py

user_0 = {'username': 'efermi','first': 'enrico','last': 'fermi',}
1 for key, value in user_0.items():
2 print("\nKey: " + key)
3 print("Value: " + value)

如1所示,要编写用于遍历字典的for循环,可声明两个变量,用于存储键—值对中的键和值。 对于这两个变量,可使用任何名称。下面的代码使用了简单的变量名,这完全可行:

for k, v in user_0.items() 

for语句的第二部分包含字典名和方法items()(见1),它返回一个键—值对列表。接下来, for循环依次将每个键—值对存储到指定的两个变量中。在前面的示例中,我们使用这两个变量来 打印每个键(见 2 )及其相关联的值(见 3 )。第一条print语句中的"\n"确保在输出每个键—值对 前都插入一个空行:

Key: last
Value: fermi
Key: first
Value: enrico
Key: username
Value: efermi

注意,即便遍历字典时,键—值对的返回顺序也与存储顺序不同。Python不关心键—值对的存 储顺序,而只跟踪键和值之间的关联关系。

在6.2.6节的示例favorite_languages.py中,字典存储的是不同人的同一种信息;对于类似这 样的字典,遍历所有的键—值对很合适。如果遍历字典favorite_languages,将得到其中每个人 的姓名和喜欢的编程语言。由于其中的键都是人名,而值都是语言,因此我们在循环中使用变量 name和language,而不是key和value,这让人更容易明白循环的作用:

favorite_languages.py

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python',}
1 for name, language in favorite_languages.items():
2 print(name.title() + "'s favorite language is " +language.title() + ".") 

1 处的代码让Python遍历字典中的每个键—值对,并将键存储在变量name中,而将值存储在变 量language中。这些描述性名称能够让人非常轻松地明白print语句(见2 )是做什么的。 仅使用几行代码,我们就将全部调查结果显示出来了:

Jen's favorite language is Python.
Sarah's favorite language is C.
Phil's favorite language is Python.
Edward's favorite language is Ruby.

即便字典存储的是上千乃至上百万人的调查结果,这种循环也管用

6.3.2 遍历字典中的所有键

在不需要使用字典中的值时,方法keys()很有用。下面来遍历字典favorite_languages,并 将每个被调查者的名字都打印出来:

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python',}
1 for name in favorite_languages.keys():print(name.title())

1 处的代码行让Python提取字典favorite_languages中的所有键,并依次将它们存储到变量 name中。输出列出了每个被调查者的名字:

Jen
Sarah
Phil
Edward

遍历字典时,会默认遍历所有的键,因此,如果将上述代码中的for name in favorite_ languages.keys():替换为for name in favorite_languages:,输出将不变。

如果显式地使用方法keys()可让代码更容易理解,你可以选择这样做,但如果你愿意,也可 省略它。

在这种循环中,可使用当前键来访问与之相关联的值。下面来打印两条消息,指出两位朋友 喜欢的语言。我们像前面一样遍历字典中的名字,但在名字为指定朋友的名字时,打印一条消息, 指出其喜欢的语言:

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python',}
1 friends = ['phil', 'sarah']
for name in favorite_languages.keys():print(name.title())
2 if name in friends:print(" Hi " + name.title() +", I see your favorite language is " +
3 favorite_languages[name].title() + "!")

在 1 处,我们创建了一个列表,其中包含我们要通过打印消息,指出其喜欢的语言的朋友。 在循环中,我们打印每个人的名字,并检查当前的名字是否在列表friends中(见 2 )。如果在列 表中,就打印一句特殊的问候语,其中包含这位朋友喜欢的语言。为访问喜欢的语言,我们使用 了字典名,并将变量name的当前值作为键(见 3 )。每个人的名字都会被打印,但只对朋友打印 特殊消息:

Edward
PhilHi Phil, I see your favorite language is Python!
SarahHi Sarah, I see your favorite language is C!
Jen 

你还可以使用keys()确定某个人是否接受了调查。下面的代码确定Erin是否接受了调查:

favorite_languages = {'jen': 'python','sarah': 'c','edward': 'ruby','phil': 'python',}if 'erin' not in favorite_languages.keys():
print("Erin, please take our poll!")

方法keys()并非只能用于遍历;实际上,它返回一个列表,其中包含字典中的所有键,因此 1  处的代码行只是核实'erin'是否包含在这个列表中。由于她并不包含在这个列表中,因此打印 一条消息,邀请她参加调查:

Erin, please take our poll!

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博客

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


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

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

相关文章

风力发电对讲 IP语音对讲终端IP安防一键呼叫对讲 医院对讲终端SV-6005网络音频终端

风力发电对讲 IP语音对讲终端IP安防一键呼叫对讲 医院对讲终端SV-6005网络音频终端 目 录 1、产品规格 2、接口使用 2.1、侧面接口功能 2.2、背面接口功能 2.3、面板接口功能 3、功能使用 1、产品规格 输入电源: 12V~24V的直流电源 网络接口&am…

PID控制参数整定(调节方法)原理+图示+MATLAB调试

PID控制参数整定(调节方法)原理图示MATLAB调试 Chapter1 PID控制参数整定(调节方法)原理图示MATLAB调试序一、P参数选取二、I的调节三、D的调节四、总结 Chapter2 PID参数调整,个人经验(配输出曲线图&#…

【51单片机系列】独立按键介绍

本文是关于独立按键的介绍及使用。首先介绍了按键,包括什么是按键及使用按键时如何实现软件消抖。然后使用proteus仿真实现独立按键控制LED指示灯的操作。 之前的LED、蜂鸣器、数码管中IO口都是作为输出使用,这里通过独立按键实验介绍IO口作为输入的使用…

Edge 中的msedgewebview2总想联网

目录预览 一、问题描述二、原因分析三、解决方案四、参考链接 一、问题描述 使用Edge浏览器的时候,右下角火绒总会弹出“msedgewebview2”想要联网的弹窗,如下 点击发起程序,找到路径如下: C:\Program Files (x86)\Microsoft\…

zabbix 进阶

zabbix的字段发现机制: zabbix客户端主动和服务端联系,将自己的地址和端口发送服务端实现字段添加监控主机。 客户端是主动一方。 缺点:自定义网段中主机数量太多,登记耗时会很久,而且这个自动发现机制不是很稳定。…

【Docker一】Docker架构、镜像操作和容器操作

一、docker基本管理和概念 1、概念 docker:开源的应用容器引擎。基于go语言开发的。运行在Linux系统中的开源的轻量级的“虚拟机” docker的容器技术可用在一台主机上轻松到达为任何应用创建一个轻量级到的,可移植的,自给自足的容器 dock…

免费的数据采集软件,最新免费的几款数据采集软件【2024】

在当今数字化时代,数据是企业决策和业务发展的关键。而如何高效获取数据成为许多企业和研究机构的关注焦点。本文将深入探讨数据采集软件的种类。帮助大家选择最适合自己需求的数据采集工具。 数据采集软件种类 在众多数据采集软件中,有一类强大而多样…

postgresql自带指令命令系列二

简介 在安装postgresql数据库的时候会需要设置一个关于postgresql数据库的PATH变量 export PATH/home/postgres/pg/bin:$PATH,该变量会指向postgresql安装路径下的bin目录。这个安装目录和我们在进行编译的时候./configure --prefix [指定安装目录] 中的prefix参…

基于ssm理发店会员管理系统的设计和实现论文

摘 要 网络技术和计算机技术发展至今,已经拥有了深厚的理论基础,并在现实中进行了充分运用,尤其是基于计算机运行的软件更是受到各界的关注。加上现在人们已经步入信息时代,所以对于信息的宣传和管理就很关键。因此理发店会员信息…

Cache的基本概念和原理

目录 一. Cache的工作原理二. 局部性原理三. 性能分析四. 待解决的问题 \quad 一. Cache的工作原理 \quad 存储系统存在的问题 虽然双端口RAM、多模块存储器提高存储器的工作速度, 但是优化后的速度与CPU差距依然很大, 为了改善这个问题就出现了Cache, 来解决存储器与CPU速度不…

ubuntu安装docker及docker常用命令

docker里有三个部分 daemon 镜像 和 容器 我们需要了解的概念 容器 镜像 数据卷 文章目录 docker命令docker镜像相关命令docker容器相关命令数据卷ubuntu安装docker docker命令 #启动,停止,重启docker systemctl start docker systemctl stop docker s…

SpringBoot的依赖管理和自动配置

与其明天开始,不如现在行动! 文章目录 1 依赖管理机制2 自动配置机制2.1 初步理解2.2 完整流程 💎总结 1 依赖管理机制 为什么导入starter-web后所有相关依赖都会导入进来? 开发什么场景,导入什么场景启动器-spring-bo…

Redis 环境搭建2

文章目录 第2关:使用 Redis 第2关:使用 Redis 本文是接着上篇文章写的第二关代码,部分人再进入第二关时不会保留第一关的配置的环境,可以通过下面一句代码进行检验。 redis-cli -p 7001 -c如果进入到了redis界面就是有环境&…

问题:batchnormal训练单个batch_size就会报错吗

Batch Normalization(批标准化)是一种深度学习中的正则化技巧,它可以改进网络的训练过程。在训练神经网络时,Batch Normalization可以帮助解决内部协变量偏移(Internal Covariate Shift)的问题。 在标准的…

pytorch serve开始-Getting started

官网链接 Getting started — PyTorch/Serve master documentation 安装TorchServe和torch-model-archiver 安装依赖 注意::对于Conda,运行Torchserve需要Python >3.8。 对于基于Debian的系统/ MacOS CPU python ./ts_scripts/install_dependencies.py 对…

【Hadoop】高可用集群搭建

知识目录 一、写在前面💕二、Zookeeper安装✨三、Hadoop配置✨四、Hadoop HA自动模式✨五、HA脚本分享✨七、结语💕 一、写在前面💕 大家好!这篇文章是我在搭建Hdfs的HA(高可用)时写下的详细笔记与感想,希望能帮助到大…

Notes数据直接在Excel中统计

大家好,才是真的好。 我希望你看过前面两篇内容《Domino REST API安装和运行》和《Domino REST API安装和运行》,因为今天我们正是使用REST API方式在Excel中查询和统计Notes数据。 不过首先你得知道一个OData协议,全名Open Data Protocol(…

布隆过滤器,Redis之 bitmap,场景题【如果微博某个大V发了一条消息,怎么统计有多少人看过了】

文章目录 一、什么是 bitmap1-1、Bitmap 相关命令二、bitmap 和 set 对比2-1、数据准备2-2、内存对比2-3、性能对比三、布隆过滤器3-1、理论主要作用如何将数据放到过滤器内呢?注意事项布隆过滤器 有两个重要的参数3-2、代码实现3-3、Java中的hash函数最近面试,面试官问了一个…

Windows系统Java开发环境安装

总结一下Java软件开发工程师常见的环境的安装,仅限Windows环境。 以下下载链接均来自官网,网络条件自己克服。 目录 1. JDKJDK Oracle 官网下载地址配置系统环境变量 2. Mavenapache maven 官网地址本地仓库和中央仓库配置配置系统环境变量 3. GitGit 官…

springboot3 liquibase SQL执行失败自动回滚,及自动打tag

一&#xff1a; 自动执行回滚&#xff0c; 已执行成功的忽略&#xff0c;新sql执行失败则执行新sql文件中的回滚sql pom.xml <dependency> <groupId>org.liquibase</groupId> <artifactId>liquibase-core</artifactId> <version>4.25.0&…