纯干货-个人整理——字典和列表的不同点和相同点

2023-10-14 23:59

本文主要是介绍纯干货-个人整理——字典和列表的不同点和相同点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 字典和列表的不同点

1、列表中的元素都有自己明确的“位置”,即使看似相同的元素,只要在列表中所处的位置不同,它们就是两个不同的元素。比如:

# 列表
1 student1 = ['小明','小红','小刚']
2 student2 = ['小刚','小明','小红']
3 print(student1 == student2)  # False# 字典
4 scores1 = {'小明':95,'小红':90,'小刚':100}
5 scores2 = {'小刚':100,'小明':95,'小红':90}
6 print(scores1 == scores2)    #True

2、字典相对列表显得随和,调动顺序也不影响。因为列表中的数据是有序排列的,字典中的数据是随机排列的。

  • 总结:
    列表有序,要用偏移量定位,
    字典无序,通过唯一的键来取值

2.字典和列表的相同点

  • 1、在列表和字典中,如果要修改元素,都可用赋值语句来完成
1 list1 = ['小明','小红','小刚','小美']
2 list1[1] = '小蓝'
3 print(list1)
4 # ['小明','小红','小刚','小美','小蓝']5 dict1 = {'小明':'男'}
6 dict1['小明'] = '女'
7 print(dict1)
8 # {'小明':'女'}
  • 2、支持任意嵌套:列表可嵌套其他列表和字典,字典也可嵌套其他字典和列表
  • 一、列表嵌套列表
    举例:一个以四人为单位的学习小组,列表的形式可以写成:
1 students = [['小明','小红','小刚','小美'],['小强','小兰','小伟','小芳']]

students 这个列表是由两个子列表组成的,如何取出 ‘小芳’ ?

  • 提取这种多级嵌套的列表/字典时,要一层一层的取出,类似于剥洋葱
  • 在这里插入图片描述
  • 所以代码可以这样写:
1 students = [['小明','小红','小刚','小美'],['小强','小兰','小伟','小芳']]
2 print(students[1][3])
  • 二、字典嵌套字典
  • 和列表嵌套类似,需要一层一层的取出,
  • 举例,要取出 ‘小芳’ 的成绩
1 scores = {
2            '第一组':{'小明':95,'小红':90,'小刚':100,'小美':85},
3            '第二组':{'小强':99,'小兰':89,'小伟':93,'小芳':88}
4            }
5 print(scores['第二组']['小芳'])
  • 三、列表和字典相互嵌套
1 # 最外层是大括号,所以是字典嵌套列表,先找到字典的键对应的列表,再判断列表中要取出的元素的偏移量
2 students = {
3               '第一组':['小明','小红','小刚','小美'],
4               '第二组':['小强','小兰','小伟','小芳']
5              }
6 print(['第一组'][3])
7 # 取出'第一组'对应列表偏移量为3的元素,即'小美'
8
9 # 最外层是中括号,所以是列表嵌套字典,先判断字典是列表的第几个元素,再找出要取出的值相对应的键
10 scores = [
11             {'小明':95,'小红':90,'小刚':100,'小美':85},
12             {'小强':99,'小兰':89,'小伟':93,'小芳':88}
13           ] 
14 print([1]['小强'])
15 #先定位到列表偏移量为1的元素,即第二个字典,再取出字典里键为'小强'对应的值,即99。

这篇关于纯干货-个人整理——字典和列表的不同点和相同点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/214025

相关文章

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

python 字典d[k]中key不存在的解决方案

《python字典d[k]中key不存在的解决方案》本文主要介绍了在Python中处理字典键不存在时获取默认值的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录defaultdict:处理找不到的键的一个选择特殊方法__missing__有时候为了方便起见,

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

c++的初始化列表与const成员

初始化列表与const成员 const成员 使用const修饰的类、结构、联合的成员变量,在类对象创建完成前一定要初始化。 不能在构造函数中初始化const成员,因为执行构造函数时,类对象已经创建完成,只有类对象创建完成才能调用成员函数,构造函数虽然特殊但也是成员函数。 在定义const成员时进行初始化,该语法只有在C11语法标准下才支持。 初始化列表 在构造函数小括号后面,主要用于给

POJ2001字典树

给出n个单词,求出每个单词的非公共前缀,如果没有,则输出自己。 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.io.UnsupportedEncodingException;

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank&nbsp;正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money