'dict_values' object does not support indexing, Python字典dict中由value查key
Python字典dict中由value查key
众所周知,字典dict最大的好处就是查找或插入的速度极快,并且不想列表list一样,随着key的增加越来越复杂。但是dict需要占用较大的内存空间,换句话说,字典dict是以空间换速度。详细请见如下示例:
#------------------------------------------------------------------------------------
student = {'小萌': '1001', '小智': '1002', '小强': '1003', '小明': '1004'}
#------------------------------------------------------------------------------------
由key查value很简单,直接调用:dict ['key'],如下:
#-----------------------------------------------------------------------------------
>>> student ['小强']
结果显示:'1003'
#-----------------------------------------------------------------------------------
但如果此时,我们想由value查找key,则会相对复杂一点,一般来说可通过如下3种方式实现:
#-----------------------------------------------------------------------------------
A. 充分利用 keys() 、values()、index() 函数
>>> list (student.keys()) [list (student.values()).index ('1004')]
结果显示: '小明'
#-----------------------------------------------------------------------------------
B. 通过定义get_key函数的方式
>>> def get_key (dict, value):
return [k for k, v in dict.items() if v == value]
>>> get_key (student, '1002')
结果显示:'小智'
#-----------------------------------------------------------------------------------
C. 将原字典dict进行反转得新字典new_dict,由原来的K-V存储形式,变为V-K存储形式
>>> new_dict = {v : k for k, v in dict.items()}
>>> new_dict ['1001']
结果显示:'小萌'
#-----------------------------------------------------------------------------------
虽然我们可以通过以上方式获得由value查找key的目的,但是我们必须明确一点:在字典dict中,key值是唯一的,且不可变;而value可以随意取值,且不唯一。之所以强调这一点,是因为在利用上述方法时,会出现失效的情况。如下所示:
假设此时原字典student发生了一些变化,变为:
#-----------------------------------------------------------------------------------
student = {'小萌': '1001', '小智': '1002', '小强': '1003', '小明': ['1004', '1005']}
#-----------------------------------------------------------------------------------
那么再次调用上述3种方法,由value查key时,则出现:
#-----------------------------------------------------------------------------------
>>> list (student.keys()) [list (student.values()).index ('1004')]
结果显示:ValueError: '1004' is not in list
因为value不唯一,key—'小明' 对应了两个value,且他们以list形式存储着,所以如果只取其中一个value值是无法查找对应的key值,必须将多个value值组成的list视为一个整体,即:
>>> list (student.keys()) [list (student.values()).index (['1004', '1005'])]
结果显示:'小明'
#-----------------------------------------------------------------------------------
>>> def get_key (dict, value):
return [k for k, v in dict.items() if v == value]
>>> get_key (student, '1004')
结果显示:[ ]
>>> get_key (student, ['1004', '1005'])
结果显示:'小明'
#-----------------------------------------------------------------------------------
>>> new_dict = {v : k for k, v in dict.items()}
回车后系统报错:TypeError: unhashable type: 'list'
由于key不可变且唯一,当K-V反转以后,key—'小明' 对应了两个value组成的list,反过来就变成了key,即此时由list充当key,因为list是可变动的,所以这在Python中是不允许的。
python中dict根据value找到keyname
'dict_values' object does not support indexing
In Python 3, dict.values()
(along with dict.keys()
and dict.items()
) returns a view
, rather than a list. See the documentation here. You therefore need to wrap your call to dict.values()
in a call to list
like so:
v = list(d.values())
{names[i]:v[i] for i in range(len(names))}
The immediate answer is that a dict's values
method returns a non-indexable object, as the error indicates. You can get around that by passing to to list:
list(word_centroid_map.values())
But really you'd do better to rewrite your loop like this:
for key, value word_centroid_map.items():
if value == cluster:
words.append(key)
Or even better, use a list comprehension:
words = [k for k, v in word_centroid_map.items() if v == cluster]
'dict_values' object does not support indexing, Python字典dict中由value查key的更多相关文章
- appium 与 selenium python解决python 'WebElement' object does not support indexing 报错问题问题
再用selenium编写测试脚本时,发现出现python 'WebElement' object does not support indexing 报错问题问题,再找一些解决方法时,发现Appium ...
- django 'set' object does not support indexing
在定义Model之后使用syncdb 同步的时候报出这个错误,检查之后发现是用错了.在model的Meta里面,排序这些用的应该是 ordering = ['last','first','middle ...
- python字典dict的增、删、改、查操作
## python字典dict的增.删.改.查操作dict = {'age': 18, 'name': 'jin', 'sex': 'male', }#增# dict['heigh'] = 185 # ...
- Python 字典 dict() 函数
描述 Python 字典 dict() 函数用于创建一个新的字典,用法与 Pyhon 字典 update() 方法相似. 语法 dict() 函数函数语法: dict(key/value) 参数说明: ...
- python 字典dict - python基础入门(15)
前面的课程讲解了字符串str/列表list/元组tuple,还有最后一种比较重要的数据类型也需要介绍介绍,那就是python字典,俗称:dict. python中的字典可与字符串/列表/元组不同,因为 ...
- Python——字典dict()详解
一.字典 字典是Python提供的一种数据类型,用于存放有映射关系的数据,字典相当于两组数据,其中一组是key,是关键数据(程序对字典的操作都是基于key),另一组数据是value,可以通过key来进 ...
- Python笔记·第六章——字典 (dict) 的增删改查及其他方法
字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据.python对key进行哈希函数运算,根据计算的结果决定value的存储地址,所以字典是无序存储的,且key必须是可 ...
- Python字典 (dict)
作者博文地址:http://www.cnblogs.com/spiritman/ 字典是Python语言中唯一的映射类型.字典对象是可变的,它是一个容器类型,支持异构.任意嵌套. 创建字典 语法:{k ...
- Python字典(dict)使用技巧
字典dict是Python中使用频率非常高的数据结构,关于它的使用,也有许多的小技巧,掌握这些小技巧会让你高效地的使用dict,也会让你的代码更简洁. 1.默认值 假设name_for_userid存 ...
随机推荐
- 【BZOJ】1596: [Usaco2008 Jan]电话网络
[算法]树上贪心 [题解] 因为一个点必须被覆盖,那么它如果没有被子树节点覆盖的话,就覆盖它的父节点. 从叶子开始贪心. 注意,如果它自己已经被选了就不需要选父节点了. #include<cst ...
- bzoj 2190 线性生成欧拉函数表
首先我们知道,正方形内个是对称的,关于y=x对称,所以只需要算出来一半的人数 然后乘2+1就行了,+1是(1,1)这个点 开始我先想的递推 那么我们对于一半的三角形,一列一列的看,假设已经求好了第I- ...
- 【转】Linux Futex的设计与实现
引子在编译2.6内核的时候,你会在编译选项中看到[*] Enable futex support这一项,上网查,有的资料会告诉你"不选这个内核不一定能正确的运行使用glibc的程序" ...
- go语言的定时器
package main import ( "fmt" "time" ) func main(){ //创建一个定时器,时间为2s,2s过后会自动往通道里面写入 ...
- WCF测试小程序
using System;using System.Collections.Generic;using System.Linq;using System.Runtime.Serialization;u ...
- 【SQL】约束与触发器2
3.修改约束 3.1给约束命名 按如下格式命名: name ) CONSTRAINT NameIsKey PRIMARY KEY gender ) CONSTRAINT NoAndro CHECK ( ...
- Spring Boot 项目部署到本地Tomcat,出现访问路径问题
首先确定war 包没问题,把war包放在webapps目录下,访问http://localhost:8080/ + 项目名称 发现首页可以访问但css,js请求都是404,跳转页面也是404 解决方法 ...
- CWnd创建WS_CHILD和WS_POPUP窗口的不同
转载:http://blog.csdn.net/tangaowen/article/details/6054152 最近在写一个从CWnd派生出来的自绘窗口,以前在包装自己的类的Create函数都是这 ...
- 一个杀不死的小强,kill进程无效的原因 记录故障排查过程中kill进程无效的分析过程
今天在处理一个机器异常负载(1000+)的问题,碰到了一个从未碰到过的情况,遇到了一个异常顽固的分子.我使用了所能想到的所有杀进程的方法,却始终无法干掉这个顽固分子,最后终于在谷歌大神的指引下,干掉了 ...
- WEB前端工程师整理的原生JavaScript经典百例
一.原生JavaScript实现字符串长度截取 二.原生JavaScript获取域名主机 三.原生JavaScript转义html标签 四.原生JavaScript时间日期格式替换 Date.prot ...