Python字典和集合初窥

简介: Python字典和集合初窥

1 字典

  • 字典和列表类似,同样是可变序列,不过与列表不同,字典是无序的。
  • 字典的主要特征:
主要特征 解释
通过键而不是通过索引来读取元素 字典类型有时也称为关联数组或者散列表(hash)。它是通过键将一系列的值联系起来的,这样就可以通过键从字典中获取指定项,但不能通过索引来获取。
字典是任意数据类型的无序集合 和列表、元组不同,通常会将索引值 0 对应的元素称为第一个元素,而字典中的元素是无序的。
字典是可变的,并且可以任意嵌套 字典可以在原处增长或者缩短(无需生成一个副本),并且它支持任意深度的嵌套,即字典存储的值也可以是列表或其它的字典。
字典中的键必须唯一 字典中,不支持同一个键出现多次,否则只会保留最后一个键值对。
字典中的键必须不可变 字典中每个键值对的键是不可变的,只能使用数字、字符串或者元组,不能使用列表。

1.1 字典的创建和删除

  • 字典的每个元素都包含“键”和“值”
  • '“键”和“值”之间使用“ : ”号(冒号)隔开
  • 所有元素放在一个大{}中
  • 语法:
mydict = {"key1": "value1", "key2": "value2", "key3": "value3", ..., "keyn":"valuen"}
  • 说明:

①mydict :字典名称
②key1-keyn:元素的键,唯一的,不可变,可以是字符串、数字、元组等
③value1-valuen:元素的值,任意数据,不唯一。

# -*- coding:utf-8 -*-

# 创建字典
student_info = {"name": "susan", "age": 18, "number": 123456, "date": 20201229}
print(student_info)

# 创建空字典
my_dict = {}
my_dict1 = dict()
print(my_dict)
print(my_dict1)

结果:

{'name': 'susan', 'age': 18, 'number': 123456, 'date': 20201229}
{}
{}
# -*- coding:utf-8 -*-

# 1、通过映射函数创建字典
# mydict = dict(zip(list1, list2))
# zip()是将多个列表或元组对应位置的元素组合为元组,返回包含这些内容的zip对象,可使用list、tuple将zip对象转换为列表和元组

list1 = {"name", "age", "number", "date"}
list2 = {"susan", 18, 12345678, 20201229}
mydict = dict(zip(list1, list2))
print(mydict)

# 2、通过给定的“关键字参数”创建字典
# my_dict = dict(key1=value1, key2=valye2, ...)

my_dict = dict(姓名="susan", 年龄=20, 学号=12345678, 日期=20201229)
print(my_dict)

# 3、使用dict对象的fromkeys()方法创建值为空的字典
# my_dict1 = dict.fromkeys(mylist)
mylist = ["姓名", "年龄", "学号", "日期"]
my_dict1 = dict.fromkeys(mylist)
print(my_dict1)

# 4、使用已经存在的列表和元组创建字典
my_tuple = ("姓名", "年龄", "学号", "日期")
my_list2 = ["susan", 18, 12345678, 20201229]
my_dict2 = {my_tuple:my_list2}
print(my_dict2)

结果:

{'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678}
{'姓名': 'susan', '年龄': 20, '学号': 12345678, '日期': 20201229}
{'姓名': None, '年龄': None, '学号': None, '日期': None}
{('姓名', '年龄', '学号', '日期'): ['susan', 18, 12345678, 20201229]}

1.2 访问字典

  • 直接使用print()输出字典的内容
  • 使用“键值对”访问字典
  • 使用get()方法获取指定键的值
# -*- coding:utf-8 -*-

my_dict = {'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678}

# 1、直接print()输出
print(my_dict)

# 2、使用键值对
print(my_dict["name"])
print(my_dict["number"])

# 3、使用get()方法
print(my_dict.get("name"))
print(my_dict.get("number"))

结果:

{'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678}
18
20201229
18
20201229

1.3 遍历字典

  • 使用字典对象的items()方法获取字典的“键值对”列表
  • 语法:
my_dict.items()
  • 说明:

①my_dict:字典对象
②返回值:可遍历的(“键值对”)元组列表,可使用for循环遍历元组

# -*- coding:utf-8 -*-

my_dict = {'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678}

my_tuple = my_dict.items()
print(my_tuple)

# 遍历元组对象,获取字典每个元素
for item in my_tuple:
    print(item)

# 遍历元组对象,获取每个元素的键和值
for key, value in my_tuple:
    print(key, value)

# 还有values()、keys()方法,使用同items()方法类似

结果:

dict_items([('name', 18), ('age', 'susan'), ('number', 20201229), ('date', 12345678)])
('name', 18)
('age', 'susan')
('number', 20201229)
('date', 12345678)
name 18
age susan
number 20201229
date 12345678

1.4 添加、修改和删除字典元素

  • 添加:
# 语法
my_dict[key] = value
# -*- coding:utf-8 -*-

my_dict = {'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678}

print(my_dict)
my_dict["color"] = "yellow"
print(my_dict)

结果:

{'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678}
{'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678, 'color': 'yellow'}
  • 修改:

直接修改对应的键的值即可。

# -*- coding:utf-8 -*-

my_dict = {'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678}

print(my_dict)
my_dict["name"] = "susan"
my_dict["age"] = 18
print(my_dict)

结果:

{'name': 18, 'age': 'susan', 'number': 20201229, 'date': 12345678}
{'name': 'susan', 'age': 18, 'number': 20201229, 'date': 12345678}

1.5 字典推导式

可以快速生成一个字典

# -*- coding:utf-8 -*-

import random

my_dict = {i:random.randint(1, 10) for i in range(1, 6)}
print(my_dict)

结果:

{1: 10, 2: 6, 3: 8, 4: 2, 5: 2}

2 集合

  • 同数学中的集合基本类似,也可用于保存不重复的元素
  • set集合是无序可变的,frozenset是不可变集合

2.1 集合的创建

# -*- coding:utf-8 -*-

# 1、直接使用{}进行创建
# 语法:setname = {e1, e2, e3, ... en}

setname1 = {"红色", "黄色", "白色", "黑色", "蓝色", "绿色"}
setname2 = {11, 22, 33, 44, 55, 66}
setname3 = {"学生信息", 123456, ("susan", 18)}

print(setname1)
print(setname2)
print(setname3)

# 2、使用set()函数创建
setname4 = set("我们都有一个小目标:一个亿")
setname5 = set([66, 77, 88, 99, 100])
setname6 = set(("说实话", "我真的很饿"))
print(setname4)
print(setname5)
print(setname6)

结果:

{'绿色', '红色', '黄色', '黑色', '蓝色', '白色'}
{33, 66, 11, 44, 22, 55}
{123456, '学生信息', ('susan', 18)}
{'一', ':', '小', '有', '们', '目', '个', '标', '我', '都', '亿'}
{66, 99, 100, 77, 88}
{'说实话', '我真的很饿'}

2.2 集合的添加和删除

# -*- coding:utf-8 -*-

# 1、向集合中添加元素
setname1 = {"红色", "黄色", "白色", "黑色", "蓝色", "绿色"}
print("原集合为:{}".format(setname1))
setname1.add("新添加的颜色")
print("添加后的集合为:{}".format(setname1))

# 2、从集合中删除元素
# del删除整个集合
# pop() 移除一个元素
# remove()移除指定元素
# clear()清空集合
setname2 = {11, 22, 33, 44, 55, 66}
print(setname2)
del setname2
# print(setname2) # 删除后打印会报错的

setname3 = {110, 220, 330, 440, 550, 660}
# print("setname3集合本身所有元素为:".format(str(setname3)))
print("集合本身为", setname3)
setname3.pop()
print("setname3删除一个元素为:", setname3)
setname3.remove(660)
print("setname3删除指定元素660为:", setname3)

结果:

原集合为:{'黄色', '蓝色', '红色', '绿色', '黑色', '白色'}
添加后的集合为:{'黄色', '蓝色', '红色', '新添加的颜色', '绿色', '黑色', '白色'}
{33, 66, 11, 44, 22, 55}
集合本身为 {550, 330, 110, 660, 440, 220}
setname3删除一个元素为: {330, 110, 660, 440, 220}
setname3删除指定元素660为: {330, 110, 440, 220}

2.3 集合的交集、并集和差集运算

  • 使用的符号为:交集(&)、并集(|)、差集(-)
# -*- coding:utf-8 -*-

setname1 = {"红色", "黄色", "白色"}
setname2 = { "黑色", "蓝色", "白色", "无色"}

print("集合setname1为:", setname1)
print("结合setname2为:", setname2)

print("交集为:", setname1 & setname2)
print("并集为:", setname1 | setname2)
print("差集为:", setname1 - setname2)

结果:

集合setname1为: {'白色', '红色', '黄色'}
结合setname2为: {'白色', '黑色', '蓝色', '无色'}
交集为: {'白色'}
并集为: {'黑色', '蓝色', '黄色', '无色', '白色', '红色'}
差集为: {'红色', '黄色'}

3 列表、元素、字典、集合的区别

数据结构 是否可变 是否重复 是否有序 定义符号
列表 可变 可重复 有序 [ ]
元组 不可变 可重复 有序 ( )
字典 可变 可重复 无序 {key:value}
集合 可变 不可重复 无序 { }
目录
相关文章
|
2月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
189 1
|
3月前
|
存储 JSON 算法
Python集合:高效处理无序唯一数据的利器
Python集合是一种高效的数据结构,具备自动去重、快速成员检测和无序性等特点,适用于数据去重、集合运算和性能优化等场景。本文通过实例详解其用法与技巧。
137 0
|
4月前
|
存储 索引 Python
python 集合的所有基础知识
python 集合的所有基础知识
203 0
|
2月前
|
存储 Java 索引
(Python基础)新时代语言!一起学习Python吧!(二):字符编码由来;Python字符串、字符串格式化;list集合和tuple元组区别
字符编码 我们要清楚,计算机最开始的表达都是由二进制而来 我们要想通过二进制来表示我们熟知的字符看看以下的变化 例如: 1 的二进制编码为 0000 0001 我们通过A这个字符,让其在计算机内部存储(现如今,A 字符在地址通常表示为65) 现在拿A举例: 在计算机内部 A字符,它本身表示为 65这个数,在计算机底层会转为二进制码 也意味着A字符在底层表示为 1000001 通过这样的字符表示进行转换,逐步发展为拥有127个字符的编码存储到计算机中,这个编码表也被称为ASCII编码。 但随时代变迁,ASCII编码逐渐暴露短板,全球有上百种语言,光是ASCII编码并不能够满足需求
168 4
|
3月前
|
机器学习/深度学习 数据采集 并行计算
多步预测系列 | LSTM、CNN、Transformer、TCN、串行、并行模型集合研究(Python代码实现)
多步预测系列 | LSTM、CNN、Transformer、TCN、串行、并行模型集合研究(Python代码实现)
360 2
|
3月前
|
存储 JSON 数据管理
Python字典:高效数据管理的瑞士军刀
Python字典基于哈希表实现,提供接近O(1)的高效查找,支持增删改查、遍历、合并等丰富操作,广泛应用于计数、缓存、配置管理及JSON处理。其灵活性与性能使其成为数据处理的核心工具。
504 0
|
3月前
|
存储 缓存 安全
Python字典:从入门到精通的实用指南
Python字典如瑞士军刀般强大,以键值对实现高效数据存储与查找,广泛应用于配置管理、缓存、统计等场景。本文详解字典基础、进阶技巧、实战应用与常见陷阱,助你掌握这一核心数据结构,写出更高效、优雅的Python代码。
91 0
|
安全 网络安全 文件存储
思科设备巡检命令Python脚本大集合
【10月更文挑战第18天】
536 1
思科设备巡检命令Python脚本大集合
|
8月前
|
存储 缓存 安全
Python frozenset 集合详解:不可变集合的终极指南
frozenset是Python中一个常被忽视但极具价值的不可变集合类型。本文深入解析其本质、操作方法与应用场景,揭示其通过不可变性带来的安全性与性能优势。从底层实现到实战案例,涵盖字典键使用、缓存优化及类型注解等高级场景。同时对比性能数据,提供最佳实践指南,并展望Python 3.11+中的优化。掌握frozenset,可为代码带来更强健性与效率,适合多种特定需求场景。
305 5
|
9月前
|
存储 人工智能 索引
Python数据结构:列表、元组、字典、集合
Python 中的列表、元组、字典和集合是常用数据结构。列表(List)是有序可变集合,支持增删改查操作;元组(Tuple)与列表类似但不可变,适合存储固定数据;字典(Dictionary)以键值对形式存储,无序可变,便于快速查找和修改;集合(Set)为无序不重复集合,支持高效集合运算如并集、交集等。根据需求选择合适的数据结构,可提升代码效率与可读性。

推荐镜像

更多