【Python】Dict模块
通过键而不是通过索引来读取元素 | 字典类型有时也称为关联数组或者散列表(hash)。它是通过键将一系列的值联系起来的,这样就可以通过键从字典中获取指定项,但不能通过索引来获取。 |
字典是任意数据类型的无序集合 | 和列表、元组不同,通常会将索引值 0 对应的元素称为第一个元素,而字典中的元素是无序的。 |
字典是可变的,并且可以任意嵌套 | 字典可以在原处增长或者缩短(无需生成一个副本),并且它支持任意深度的嵌套,即字典存储的值也可以是列表或其它的字典。 |
字典中的键必须唯一 | 字典中,不支持同一个键出现多次,否则只会保留最后一个键值对。 |
字典中的键必须不可变 | 字典中每个键值对的键是不可变的,只能使用数字、字符串或者元组,不能使用列表。 |
使用 { } 创建字典
由于字典中每个元素都包含两部分,分别是键(key)和值(value),因此在创建字典时,键和值之间使用冒号:
分隔,相邻元素之间使用逗号,
分隔,所有元素放在大括号{ }
中。
使用{ }
创建字典的语法格式如下:
dictname = {'key':'value1', 'key2':'value2', ..., 'keyn':valuen}
其中 dictname 表示字典变量名,keyn : valuen 表示各个元素的键值对。需要注意的是,同一字典中的各个键必须唯一,不能重复。
如下代码示范了使用花括号语法创建字典:
#使用字符串作为key scores = {'数学': 95, '英语': 92, '语文': 84} print(scores) #使用元组和数字作为key dict1 = {(20, 30): 'great', 30: [1,2,3]} print(dict1) #创建空元组 dict2 = {} print(dict2)
运行结果为:
{'数学': 95, '英语': 92, '语文': 84}
{(20, 30): 'great', 30: [1, 2, 3]}
{}
可以看到,字典的键可以是整数、字符串或者元组,只要符合唯一和不可变的特性就行;字典的值可以是 Python 支持的任意数据类型。
2) 通过 fromkeys() 方法创建字典
Python 中,还可以使用 dict 字典类型提供的 fromkeys() 方法创建带有默认值的字典,具体格式为:
dictname = dict.fromkeys(list,value=None)
其中,list 参数表示字典中所有键的列表(list);value 参数表示默认值,如果不写,则为空值 None。
请看下面的例子:
knowledge = ['语文', '数学', '英语']字典
scores = dict.fromkeys(knowledge, 60) print(scores)
dict5 = dict.fromkeys("abc", 'x')
print(dict5)
# {'a': 'x', 'b': 'x', 'c': 'x'}
_dict5 = dict.fromkeys({1, 2, 3})
print(_dict5)
# {1: None, 2: None, 3: None}
运行结果为:
{'语文': 60, '英语': 60, '数学': 60}
可以看到,knowledge 列表中的元素全部作为了 scores 字典的键,而各个键对应的值都是 60。这种创建方式通常用于初始化字典,设置 value 的默认值。
3) 通过 dict() 映射函数创建字典
通过 dict() 函数创建字典的写法有多种,表 2 罗列出了常用的几种方式,它们创建的都是同一个字典 a。
a = dict(str1=value1, str2=value2, str3=value3) | str 表示字符串类型的键,value 表示键对应的值。使用此方式创建字典时,字符串不能带引号。 |
#方式1 demo = [('two',2), ('one',1), ('three',3)] #方式2 demo = [['two',2], ['one',1], ['three',3]] #方式3 demo = (('two',2), ('one',1), ('three',3)) #方式4 demo = (['two',2], ['one',1], ['three',3]) a = dict(demo) |
向 dict() 函数传入列表或元组,而它们中的元素又各自是包含 2 个元素的列表或元组,其中第一个元素作为键,第二个元素作为值。 |
keys = ['one', 'two', 'three'] #还可以是字符串或元组 values = [1, 2, 3] #还可以是字符串或元组 a = dict( zip(keys, values) ) |
通过应用 dict() 函数和 zip() 函数,可将前两个列表转换为对应的字典。 |
3) 通过推导创建字典
dict6 = {i: 2 * i for i in range(3)} print(dict6) # {0: 0, 1: 2, 2: 4}
注意,无论采用以上哪种方式创建字典,字典中各元素的键都只能是字符串、元组或数字,不能是列表。列表是可变的,不能作为键。
4) 创建键值一对多的字典
一般写法: 使用Python3标准库,collections模块的类:defaultdict([default_factory[, …]])
- 需要导入collections模块的defaultdict
- 接受一个工厂函数作为参数,default_factory可以是list,tuple,set等
- defaultdict会根据method_factory参数不同为key设置默认值,而相同情况下普通Dict会抛出KeyError
from collections import defaultdict dict2 = defaultdict(list) dict2["one"].append(1) dict2["one"].append(2) dict2["one"].append(3) print(dict2) # defaultdict(<class 'list'>, {'one': [1, 2, 3]}) print(dict2["two"]) # key"two"不存在 根据参数是list返回空列表 []
6) 创建有序字典
创建有序Dict
推荐写法: 使用Python3的标准库,collections模块的类:OrderedDict([items])
- OrderedDict内部维护着一个根据键插入顺序排序的双向链表,每添加一个新元素,它会被放到链表尾部
- 缺点:相比于普通Dict,OrderedDict会造成更多内存消耗
dict1 = OrderedDict() dict1["one"] = 1 dict1["two"] = 2 dict1["three"] = 3 print(dict1) # OrderedDict([('one', 1), ('two', 2), ('three', 3)])
7) 创建空字典
推荐写法: 使用{}直接创建
推荐写法: 使用Python3的标准库,dict类内置函数:dict()
empty_dict1 = {} print(isinstance(empty_dict1, dict)) # True print(empty_dict1) # {} empty_dict2 = dict() print(isinstance(empty_dict2, dict)) # True print(empty_dict2) # {}
8) 创建有默认值的字典
推荐写法: 使用Python3的标准库,dict类内置函数:setdefault(key[, default]),key指定键,default是可选参数
- default指定默认返回值
- 若key已存在,则返回其对应的值,default不生效
- 若key不存在,若给定default返回值,则返回该值,并把键值对(key, default)插入到当前字典中
- 若key不存在,若没有给定default返回值,则返回None,并把键值对(key, None)插入到当前字典中
dict1 = {"one": 1, "two": 2, "three": 3} value = dict1.setdefault("one", 111) print(value) # key"one"存在 default不生效 1 print(dict1) # {'one': 1, 'two': 2, 'three': 3} none_value = dict1.setdefault("four") print(none_value) # key"four"不存在 None print(dict1) # 添加新元素 {'one': 1, 'two': 2, 'three': 3, 'four': None} default_value = dict1.setdefault("five", 5) print(default_value) # key"five"不存在 返回default给定值 5 print(dict1) # 添加新元素 {'one': 1, 'two': 2, 'three': 3, 'four': None, 'five': 5}
Python访问字典
列表和元组是通过下标来访问元素的,而字典不同,它通过键来访问对应的值。因为字典中的元素是无序的,每个元素的位置都不固定,所以字典也不能像列表和元组那样,采用切片的方式一次性访问多个元素。
Python 访问字典元素的具体格式为:dictname[key]
其中,dictname 表示字典变量的名字,key 表示键名。注意,键必须是存在的,否则会抛出异常。
除了上面这种方式外,Python 更推荐使用 dict 类型提供的 get() 方法来获取指定键对应的值。当指定的键不存在时,get() 方法不会抛出异常。
get() 方法的语法格式为:dictname.get(key[,default])
其中,dictname 表示字典变量的名字;key 表示指定的键;default 用于指定要查询的键不存在时,此方法返回的默认值,如果不手动指定,会返回 None。
注意,当键不存在时,get() 返回空值 None,如果想明确地提示用户该键不存在,那么可以手动设置 get() 的第二个参数,例如:
a = dict(two=0.65, one=88, three=100, four=-59) print( a.get('one') ) print( a.get('five', '该键不存在') )
Python删除字典
和删除列表、元组一样,手动删除字典也可以使用 del 关键字,例如:
a = dict(two=0.65, one=88, three=100, four=-59) print(a) del a print(a)
Dict浅拷贝
Dict浅拷贝只会拷贝当前Dict的顶层元素,不会拷贝嵌套的子对象,即原Set和拷贝Set指向同一子对象
一般写法: 使用Python3的标准库,dict类内置函数:copy(other),other指代另一个Dict
- 返回一个新Dict,与原Dict地址空间不同
- 若当前Dict包含子对象,则不会拷贝子对象,原Dict和拷贝Dict指向同一子对象
- 更新子对象会同时影响原Dict和拷贝Dict
dict1 = {"one": 1, "two": {1: 1, 2: 2}} copy1 = dict1.copy() print(dict1 == copy1) # True print(id(dict1) == id(copy1)) # False copy1.get("two")[1] = 111 print(dict1) # {'one': 1, 'two': {1: 111, 2: 2}}
一般写法: 使用Python3的标准库,copy模块的函数:copy(other),other指代另一个Dict
- 需要导入copy模块
- 返回一个新Dict,与原Dict地址空间不同
- 若当前Dict包含子对象,则不会拷贝子对象,原Dict和拷贝Dict指向同一子对象
- 更新子对象会同时影响原Dict和拷贝Dict
import copy dict1 = {"one": 1, "two": {1: 1, 2: 2}} copy1 = copy.copy(dict1) print(dict1 == copy1) # True print(id(dict1) == id(copy1)) # False copy1.get("two")[1] = 111 print(dict1) # {'one': 1, 'two': {1: 111, 2: 2}}
一般写法: 使用Python3的标准库,dict类内置函数:dict(other),other指代另一个Dict
- 返回一个新Dict,与原Dict地址空间不同
- 若当前Dict包含子对象,则不会拷贝子对象,原Dict和拷贝Dict指向同一子对象
- 更新子对象会同时影响原Dict和拷贝Dict
dict1 = {"one": 1, "two": {1: 1, 2: 2}} copy1 = dict(dict1) print(dict1 == copy1) # True print(id(dict1) == id(copy1)) # False copy1.get("two")[1] = 111 print(dict1) # {'one': 1, 'two': {1: 111, 2: 2}}
一般写法: 使用运算符”=“
- 本质是对象的引用
- 返回一个新Dict,与原Dict指向同一个地址空间,相互影响
dict1 = {"one": 1, "two": {1: 1, 2: 2}} copy1 = dict1 print(dict1 == copy1) # True print(id(dict1) == id(copy1)) # True copy1.get("two")[1] = 111 print(dict1) # {'one': 1, 'two': {1: 111, 2: 2}}
Dict深拷贝
Dict深拷贝不仅会拷贝当前Dict的顶层元素,也会拷贝嵌套的子对象,本质上是执行递归浅拷贝,原Dict和拷贝Dict完全独立,相互不影响
推荐写法: 使用Python3的标准库,copy模块的函数:deepcopy(other),other指代另一个Dict
- 需要导入copy模块
- 返回一个新Dict,与原Dict是独立的对象,地址空间不同
- 若当前Dict包含子对象,也会拷贝子对象
- 原Dict和拷贝Dict所有元素地址都是独立的,更新元素相互不影响
import copy dict1 = {"one": 1, "two": {1: 1, 2: 2}} copy1 = copy.deepcopy(dict1) print(dict1 == copy1) # True print(id(dict1) == id(copy1)) # False copy1.get("two")[1] = 111 print(dict1) # {'one': 1, 'two': {1: 1, 2: 2}}
获取Dict长度
获取字典长度
推荐写法: 使用Python3的标准库,内置函数len(s),参数可以是序列(如字符串、字节、元组、列表或范围等)或集合(如字典和集合),这里是Dict实例
dict1 = {"one": 1, "two": 2, "three": 3} length = len(dict1) print(length) # 3 empty_dict = {} empty_length = len(empty_dict) print(empty_length) # 0
Dict添加
Dict添加键值对
添加一个键值对
Dict添加单个元素;键必须是不可变对象,比如数字、字符串或元组(纯元组,没有嵌套可变对象),否则会抛出TypeError
推荐写法: 使用方括号dict1[key]=value直接赋值,指定键和值
- 若key已存在,则会修改相应的值,若key不存在,则添加元素
- 性能比update函数高
dict1 = {"one": 1, "two": 2, "three": 3} dict1["four"] = 4 print(dict1) # {'one': 1, 'two': 2, 'three': 3, 'four': 4} dict1["one"] = 111 print(dict1) # {'one': 111, 'two': 2, 'three': 3, 'four': 4}
一般写法: 使用Python3的标准库,dict类内置函数:update([other]),other指代一个字典对象或一个键值对的迭代
- 若key已存在,则会修改相应的值,若key不存在,则添加元素
- 性能比直接赋值低
dict1 = {"one": 1, "two": 2, "three": 3} # 通过关键字形式的参数添加 dict1.update(four=4) print(dict1) # {'one': 1, 'two': 2, 'three': 3, 'four': 4} # 通过元组列表参数添加 dict1.update([("five", 5)]) print(dict1) # {'one': 1, 'two': 2, 'three': 3, 'four': 4, 'five': 5} # 通过字典实例参数添加 dict1.update({"six": 6}) print(dict1) # {'one': 1, 'two': 2, 'three': 3, 'four': 4, 'five': 5, 'six': 6} # 可以使用以上任意方法修改已存在的键对应的值 dict1.update(one=111) print(dict1) # {'one': 111, 'two': 2, 'three': 3, 'four': 4, 'five': 5, 'six': 6}
添加多个键值对
Dict添加多个元素;键必须是不可变对象,比如数字、字符串或元组(纯元组,没有嵌套可变对象),否则会抛出TypeError
一般写法: 使用Python3的标准库,dict类内置函数:update([other]),other指代一个字典对象或一个键值对的迭代
- 若key已存在,则会修改相应的值,若key不存在,则添加元素
dict1 = {1: 1, 2: 2, 3: 3} # 通过关键字形式的参数添加 dict1.update(four=4, five=5) print(dict1) # {1: 1, 2: 2, 3: 3, 'four': 4, 'five': 5} # 通过元组列表参数添加 dict1.update([(6, 6), (7, 7)]) print(dict1) # {1: 1, 2: 2, 3: 3, 'four': 4, 'five': 5, 6: 6, 7: 7} # 通过字典参数添加 dict1.update({8: 8, 9: 9}) print(dict1) # {1: 1, 2: 2, 3: 3, 'four': 4, 'five': 5, 6: 6, 7: 7, 8: 8, 9: 9} # 可以使用以上任意方法修改已存在的键对应的值 dict1.update({"four": 444, "five": 555}) print(dict1) # {1: 1, 2: 2, 3: 3, 'four': 444, 'five': 555, 6: 6, 7: 7, 8: 8, 9: 9}
Dict删除
Dict删除键值对
1) 根据指定的key删除一个键值对
Dict根据指定的键删除一个键值对
推荐写法: 使用Python3的标准库,dict类内置函数:pop(key[, default]),key指定键,default是可选参数
- default指定默认返回值
- 若key已存在,则删除相应的键值对,并返回其对应的值,default不生效
- 若key不存在,若给定default返回值,则返回该值,否则抛出KeyError
- 参数不能为空
dict1 = {"one": 1, "two": 2, "three": 3} value1 = dict1.pop("one", 111) print(value1) # key"one"存在 default不生效 1 print(dict1) # {'two': 2, 'three': 3} value2 = dict1.pop("1", 111) print(value2) # key"1"不存在 返回default给定值 111 print(dict1) # {'two': 2, 'three': 3} dict1.pop("1") # key"1"不存在 抛出KeyError: '1' dict1.pop() # 抛出TypeError: pop expected at least 1 arguments, got 0
一般写法: 使用del关键字:del dict1[key],key指定键
- 若key已存在,则删除相应的键值对
- 若key不存在,则抛出KeyError
dict1 = {"one": 1, "two": 2, "three": 3} del dict1["one"] print(dict1) # {'two': 2, 'three': 3} del dict1["1"] # key"1"不存在 抛出KeyError: '1'
2) 随机删除一个键值对
Dict随机删除一个键值对
推荐写法: 使用Python3的标准库,dict类内置函数:popitem()
- 随机删除一个键值对,并以元组的形式返回该键值对
- 若Dict为空,则抛出KeyError
dict1 = {"one": 1, "two": 2, "three": 3} pop_one = dict1.popitem() print(pop_one) # ('three', 3) print(dict1) # {'one': 1, 'two': 2} empty_dict = {} empty_dict.popitem() # 抛出KeyError: 'popitem(): dictionary is empty'
3) 清空Dict
删除Dict中所有元素
推荐写法: 使用Python3的标准库,dict类内置函数:clear()
- 修改当前集合,删除Dict中所有元素
dict1 = {"one": 1, "two": 2, "three": 3} dict1.clear() print(dict1) # {}
4) 删除整个Dict
删除整个字典变量
推荐写法: 使用关键字“del”
- del作用于变量而不是对象
- del只是解除变量和对象的引用关系,而不是销毁对象释放占用的内存空间
- python的垃圾回收机制主要采用的是引用计数的方式
dict1 = {"one": 1, "two": 2, "three": 3} del dict1 print(dict1) # 抛出NameError: name 'dict1' is not defined
6. Dict更新
1) 更新指定key的value
Dict更新指定key对应的value
推荐写法: 使用方括号dict1[key]=value直接更新,指定键和值
- 若key已存在,则会修改相应的值,若key不存在,则添加元素
- 性能比update函数高
dict1 = {"one": 1, "two": 2, "three": 3} dict1["one"] = 111 print(dict1) # {'one': 111, 'two': 2, 'three': 3} dict1["four"] = 4 print(dict1) # {'one': 111, 'two': 2, 'three': 3, 'four': 4}
一般写法: 使用Python3的标准库,dict类内置函数:update([other]),other指代一个字典对象或一个键值对的迭代
- 若key已存在,则会修改相应的值,若key不存在,则添加元素
- 性能比直接赋值低
dict1 = {"one": 1, "two": 2, "three": 3} # 通过关键字形式的参数更新 dict1.update(one=111) print(dict1) # {'one': 111, 'two': 2, 'three': 3} # 通过元组列表参数更新 dict1.update([("two", 222)]) print(dict1) # {'one': 111, 'two': 222, 'three': 3} # 通过字典参数更新 dict1.update({"three": 333}) print(dict1) # {'one': 111, 'two': 222, 'three': 333} # 可以使用以上任意方法添加一个键值对 dict1.update(four=4) print(dict1) # {'one': 111, 'two': 222, 'three': 333, 'four': 4}
7. Dict查找
1) 获取value的最大值/最小值
获取value的最大值/最小值
推荐写法: 使用Python3的标准库,内置函数:max/min(iterable, *[, key, default])和zip(*iterables)
- 返回value的最大值/最小值及其对应的key构成的元组
dict1 = {"a": 123, "b": 321, "c": 200} # 获取max value及其对应的key max_tuple = max(zip(dict1.values(), dict1.keys())) print(max_tuple) # (321, 'b') # 获取min value及其对应的key min_tuple = min(zip(dict1.values(), dict1.keys())) print(min_tuple) # (123, 'a')
一般写法: 使用Python3的标准库,内置函数:max/min(iterable, *[, key, default])
- 获取value的最大值/最小值对应的key,再根据key获取对应的value
dict1 = {"a": 123, "b": 321, "c": 200} # 在一个字典上执行普通的数学运算,它们仅仅作用于键,而不是值 max_key = max(dict1) print(max_key) # 返回key的最大值 'c' # 获取最大值对应的键 max_value_key = max(dict1, key=lambda k: dict1[k]) print(max_value_key) # 'b' # 根据键获取对应的值 max_value = dict1[max_key] print(max_value) # 321
2) 获取指定key的value
获取指定key的value
推荐写法: 使用Python3的标准库,dict类内置函数:get(key[, default]),key指定键,default是可选参数
- default指定默认返回值
- 若key已存在,则返回其对应的值,default不生效
- 若key不存在,若给定default返回值,则返回该值,否则返回None
- 所以该方法永远不会引发KeyError
dict1 = {"one": 1, "two": 2, "three": 3} value = dict1.get("one", 111) print(value) # key"one"存在 default不生效 1 none_value = dict1.get("four") print(none_value) # key"four"不存在 None default_value = dict1.get("four", 4) print(default_value) # key"four"不存在 返回default给定值 4
一般写法: 使用方括号dict1[key]直接获取,指定键
- 若key已存在,则返回其对应的值
- 若key不存在,则抛出KeyError
dict1 = {"one": 1, "two": 2, "three": 3} value = dict1["one"] print(value) # 1 none_value = dict1["four"] # key"four"不存在 抛出KeyError: 'four'
3) 获取键值对列表
获取(键, 值)元组列表动态视图
推荐写法: 使用Python3的标准库,dict类内置函数:items()
- 返回Dict键值对的视图对象,当Dict更改时,会动态反映这些变化
dict1 = {"one": 1, "two": 2, "three": 3} items = dict1.items() print(items) # dict_items([('one', 1), ('two', 2), ('three', 3)]) dict1.clear() print(items) # dict_items([])
4) 获取key列表
获取key列表动态视图
推荐写法: 使用Python3的标准库,dict类内置函数:keys()
- 返回Dict键的视图对象,当Dict更改时,会动态反映这些变化
dict1 = {"one": 1, "two": 2, "three": 3} keys = dict1.keys() print(keys) # dict_keys(['one', 'two', 'three']) dict1.clear() print(keys) # dict_keys([])
5) 获取value列表
获取value列表动态视图
推荐写法: 使用Python3的标准库,dict类内置函数:values()
- 返回Dict值的视图对象,当Dict更改时,会动态反映这些变化
dict1 = {"one": 1, "two": 2, "three": 3} values = dict1.values() print(values) # dict_values([1, 2, 3]) dict1.clear() print(values) # dict_values([])
6) 从字典中提取符合条件的子集
从字典中过滤/映射符合条件的Dict
推荐写法: 使用推导式
prices = { "a": 45.23, "b": 612.78, "c": 205.55, "d": 37.20, "e": 10.75 } # ---过滤--- # 1. 获取value>200的键值对构成的字典 dict1 = {key: value for key, value in prices.items() if value > 200} print(dict1) # {'b': 612.78, 'c': 205.55} # 2. 获取names中的key对应的键值对构成的字典 names = {"d", "e"} # 以下方法1,2都可以满足要求,但运行时间测试结果显示,方法2比方法1所花费的时间更多。 # 方法1 dict2 = {key: value for key, value in prices.items() if key in names} print(dict2) # {'d': 37.2, 'e': 10.75} # 方法2 dict3 = {key: prices[key] for key in prices.keys() & names} print(dict3) # {'d': 37.2, 'e': 10.75} # ---映射--- # 1. 将value转换成整数 dict4 = {key: int(value) for key, value in prices.items()} print(dict4) # {'a': 45, 'b': 612, 'c': 205, 'd': 37, 'e': 10}
8. Dict判断
1) 判断key是否在字典中
判断key是否在字典中
推荐写法: 使用运算符“in”
- 对大小写敏感
if key in dict1: """do something""" if key not in dict1: """do something""" dict1 = {"one": 1, "two": 2, "three": 3} print("one" in dict1) # True print("one" not in dict1) # False print("One" in dict1) # False
9. Dict排序
1) 根据key对字典排序
根据key,对字典进行排序
推荐写法: 使用Python3的标准库,内置函数:sorted(iterable[, key=None[, reverse=False]),key和reverse是可选参数
- 返回一个排序列表
- iterable用于指定一个可迭代对象,这里是一个字典实例
- key用于指定排序规则,默认是None,语法是key=lambda elem:xxx
- reverse用于指定排序方向,默认是升序,语法是reverse=False/True
dict1 = {"a": 3, "c": 1, "b": 2} # item指代(键,值)元组,item[0]是键, item[1]是值 # 正序 dict_sorted = sorted(dict1.items(), key=lambda item: item[0]) print(dict_sorted) # [('a', 3), ('b', 2), ('c', 1)] # 逆序 dict_sorted_rev = sorted(dict1.items(), key=lambda item: item[0], reverse=True) print(dict_sorted_rev) # [('c', 1), ('b', 2), ('a', 3)] # ------ # 注意:sorted(dict1)默认是对key排序,而不是对整个字典 sorted1 = sorted(dict1) print(sorted1) # ['a', 'b', 'c']
2) 根据key对value排序
根据字典的键,对值进行排序
推荐写法
- 先使用内置函数sorted,根据key对字典排序
- 再使用推导式,获取value列表
- 关于sorted函数的用法,参看章节“根据key对字典排序”
dict1 = {"a": 3, "c": 1, "b": 2} list1 = sorted(dict1.items(), key=lambda item: item[0]) print(list1) # 根据key对字典排序 [('a', 3), ('b', 2), ('c', 1)] list2 = [value for key, value in list1] print(list2) # [3, 2, 1]
推荐写法
- 先使用内置函数sorted,对字典的键列表排序
- 再使用推导式,获取key对应的value
dict1 = {"a": 3, "c": 1, "b": 2} keys = sorted(dict1.keys()) list1 = [dict1[k] for k in keys] print(list1) # [3, 2, 1]
推荐写法
- 先使用内置函数sorted,对字典的键列表排序
- 再使用内置函数map,获取key对应的value
- 由于Python3.x版本中,map函数的返回一个迭代器(Python2.x版本中map返回一个列表),需要使用内置类list(iterable)进行转换
dict1 = {"a": 3, "c": 1, "b": 2} keys = sorted(dict1.keys()) list1 = list(map(dict1.get, keys)) print(list1) # [3, 2, 1]
3) 根据value对字典排序
根据value,对字典进行排序
推荐写法: 使用Python3的标准库,内置函数:sorted(iterable[, key=None[, reverse=False]),key和reverse是可选参数
- 用法同上
dict1 = {"a": 3, "c": 1, "b": 2} # item指代(键,值)元组,item[0]是键, item[1]是值 # 正序 dict_sorted = sorted(dict1.items(), key=lambda item: item[1]) print(dict_sorted) # [('c', 1), ('b', 2), ('a', 3)] # 逆序 dict_sorted_rev = sorted(dict1.items(), key=lambda item: item[1], reverse=True) print(dict_sorted_rev) # [('a', 3), ('b', 2), ('c', 1)]
4) 根据某个key对应的value对字典列表排序
根据字典中某个key对应的value,对字典列表进行排序
*推荐写法: 使用Python3的标准库,operator模块的类:itemgetter(keys)
- 需要导入operator模块的itemgetter
- keys用于指定键,接受多个key参数,多个参数使用逗号”,“隔开
from operator import itemgetter stu = [ {"id": 3, "name": "Tom", "score": 82}, {"id": 2, "name": "Jerry", "score": 67}, {"id": 1, "name": "Pig", "score": 82}, {"id": 4, "name": "Dog", "score": 98}, ] # 根据key"score"对应的value 对stu正序排序 ''' [{'id': 2, 'name': 'Jerry', 'score': 67}, {'id': 3, 'name': 'Tom', 'score': 82}, {'id': 1, 'name': 'Pig', 'score': 82}, {'id': 4, 'name': 'Dog', 'score': 98}] ''' sorted_by_score = sorted(stu, key=itemgetter("score")) print(sorted_by_score) # 根据key"score"对应的value 对stu逆序排序 ''' [{'id': 4, 'name': 'Dog', 'score': 98}, {'id': 3, 'name': 'Tom', 'score': 82}, {'id': 1, 'name': 'Pig', 'score': 82}, {'id': 2, 'name': 'Jerry', 'score': 67}] ''' sorted_by_score_rev = sorted(stu, key=itemgetter("score"), reverse=True) print(sorted_by_score_rev) # 根据key"score"和"id" 对stu正序排序(先根据"score"排序,"score"相同的情况下根据"id"排序) ''' [{'id': 2, 'name': 'Jerry', 'score': 67}, {'id': 1, 'name': 'Pig', 'score': 82}, {'id': 3, 'name': 'Tom', 'score': 82}, {'id': 4, 'name': 'Dog', 'score': 98}] ''' rows_by_score_id = sorted(stu, key=itemgetter("score", "id")) print(rows_by_score_id)