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} |
汇合 | 可变 | 不可反复 | 无序 | {} |