一:
key = [k for k,v in d.items() if v=='5']
d = {
'a':'d',
'b':['2','3','4'],
'c':'5',
'e':'5'
}
print([k for k,v in d.items() if v==['2','3','4']])
print([k for k,v in d.items() if v=='5'])
结果:
['b']
['c', 'e']
二:
key = list(d.keys())[list(d.values()).index('5')]
d = {
'a':'d',
'b':['2','3','4'],
'c':'5',
'e':'5'
}
print(list(d.keys())[list(d.values()).index(['2','3','4'])])
print(list(d.keys())[list(d.values()).index('5')])
结果:
b
c
注意:存在一个弊端,values的值不可重复。
当values的值重复时,由于列表索引的限制,只能获取到第一个符合条件的values的key。
三:
key = {v:k for k,v in d.items()}['5']
d = {
'a':'d',
'b':tuple(['2','3','4']),
'c':'5',
'e':'5'
}
print({v:k for k,v in d.items()}[tuple(['2','3','4'])])
print({v:k for k,v in d.items()}['5'])
结果:
b
e
注意:存在两个弊端:
1、values的值不可为可变类型。
由于字典的键值key为不可变类型,所以当values中含有可变类型的值时,应提前转化为不可变类型, 否则会报错,如举例中,把可变类型列表list转为不可变类型元组tuple。
2、values的值不可重复。
当values的值重复时,由于字典的规则,上述方法在循环过程中,相当于不断重新给v(上述方法把k和v置换位置,此时v为键)赋值,故而只能获取到最后一个符合条件的values的key。