python中字典的键是唯一的吗_在python3中反转字典中的键和值(值不唯一)

我知道当值是唯一的时,如何简单地在字典中反转键和值.

但是当值不唯一时如何反转.

根据要求,如果值出现不止一次,我需要使用set来将它们组合在一起.

防爆.输入d = {‘a’:1,’b’:2,’c’:1,’d’:2}输出d = {1,{‘a’,’c’},2,{‘b’ ,’C’}}

我在下面编写了相当愚蠢的代码,但因为我只创建了一个集合,因此所有显示多次的值都在该集合中.

def change(d):

inverted_l = list(map(lambda t:(t[1],t[0]), d.items()))

store_key = [] #for store the key to check if value appear more than one

new_d = {}

x = set()

for i in range(len(inverted_l)):

store_key.append(inverted_l[i][0])

for i in range(len(store_key)):

if store_key.count(store_key[i])> 1:

x.add(inverted_l[i][1]) #I think the problem is I need create set

#each time, but I don't know how to do that

new_d[store_key[i]] = x

else:

new_d[store_key[i]] = inverted_l[i][1]

return new_d

print(sorted(change({'a':1, 'b':2, 'c':1,'d':2}).items()))

我错误的输出是[(1,{‘c’,’d’,’b’,’a’}),(2,{‘c’,’d’,’b’,’a’})]但是我需要[(1,{‘a’,’c’}),(2,{‘b’,’d’})]

补充:我尝试你的代码,但是当我测试print时发生错误(sorted(invert_dict({‘a’:1,’b’:2,’c’:1}).items()))

我希望我的结果是[(1,{‘a’,’c’}),(2,’b’)]

我是python的新手,谢谢你的帮助和时间!

def invert_dict(d):

result = {}

for k in d:

if d[k] not in result:

result[d[k]] = set()

result[d[k]].add(k)

return {k: d[k] if len(d[k])>1 else d[k].pop() for k in d}

Traceback (most recent call last):

File "U:\test.py", line 9, in

print(sorted(invert_dict({'a':1, 'b':2, 'c':1}).items()))

File "U:\test.py", line 7, in invert_dict

return {k: d[k] if len(d[k])>1 else d[k].pop() for k in d}

File "U:\test.py", line 7, in

return {k: d[k] if len(d[k])>1 else d[k].pop() for k in d}

TypeError: object of type 'int' has no len()

解决方法:

我很确定你的意思是所需的输出不是设定的

d = {1,{'a','c'},2,{'b','c'}}

而是字典

d = {1:{'a','c'}, 2:{'b','c'}}

只需仔细检查一下:-).

无论如何,我会这样做:

import collections

def invert_dict(d):

result = collections.defaultdict(set)

for k in d:

result[d[k]].add(k)

return dict(result)

如果dict子类defaultdict正常,则返回可以简化为返回结果 – 如果规范非常严格,则只需要将其转换为dict.

我想下一步可​​能是“oops,不允许导入”禁止集合.defaultdict,所以我预计 – 在这种情况下,请改为(例如)

def invert_dict(d):

result = {}

for k in d:

if d[k] not in result:

result[d[k]] = set()

result[d[k]].add(k)

return result

补充:显然最新版本是至关重要的(OP当然“忘记”首先添加“无导入”约束 – 为什么他们继续对我这样做?!它会花费他们任何东西来揭示所有的限制从他们的Qs开始前面?!?!?!!)但是需要进行调整 – 单例集需要转换成他们唯一元素的非集合(一个可怕的,可怕的,不好的规范,使得结果字典几乎无法使用,并且让我强烈希望对那些似乎相信制作令人作呕的糟糕规格改善他们的教学的没有好词的人有一些尖锐的话语,但是,这是另一种咆哮).

无论如何,最好是添加一个后处理步骤:

def invert_dict(d):

result = {}

for k in d:

if d[k] not in result:

result[d[k]] = set()

result[d[k]].add(k)

return {k: d[k] if len(d[k])>1 else d[k].pop() for k in d}

没有什么比这更难了:只需将“解开”单件套装设置为带有弹出的一个项目. (接下来是什么 – 另一个愚蠢的任意约束的迟来的启示,例如“no if / else表达式”?! – )

添加(保留上面的错误代码):需要在return语句中清楚地使用结果而不是d!即最后一行必须是

return {k: result[k] if len(result[k])>1 else result[k].pop() for k in result}

标签:python,python-3-x,dictionary,duplicates,key-value

来源: https://codeday.me/bug/20190830/1766078.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/505367.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

排序算法 --- 堆排序

根据大顶堆的描述, 父节点的值始终大于子节点(如果有的话)的值, 再加上堆是完全二叉树, 可以用数组表示, 那么就可以用来进行排序. 具体做法就是, 对于随机排列的数组: 1. 首先将其构建成一个大顶堆, 根据堆的性质, 此时堆顶就是最大值. 2. 把堆顶元素与数组最后一个元素进行…

数据结构中的树 --- 红黑树

红黑树是一种几近平衡的二叉搜索树, 但不是AVL树. 1 红黑树的一些特殊性质 1. 每个节点皆为红色或者黑色。 2. 根节点是黑色。 3. 每个叶子节点(NIL)是黑色(注意, 每个叶子节点必须都为空节点, 也就是指针为nullptr, 无key值)。 4. 每个红色结点的两…

c++数据结构中 顺序队列的队首队尾_数据结构与算法—队列详解

前言栈和队列是一对好兄弟,前面我们介绍过数据结构与算法—栈详解,那么栈的机制相对简单,后入先出,就像进入一个狭小的山洞,山洞只有一个出口,只能后进先出(在外面的先出去)。而队列就好比是一个隧道&#…

二叉树的线索化

1 简介 深度优先的二叉树遍历方法有先序, 中序和后序. 那么一棵有n个节点的树, 其一共会存储2n个指针, 但是因为只有n - 1条边, 所以只有n - 1个指针会被存储, 剩下的n 1都会存为nullptr, 那么可以把所有的空指针利用起来. 其中如果某个节点的左子节点为空的话, 可以按照当前…

phpstudy apache无法启动_phpstudy和wamp哪个好

刚刚接触php的同学会想知道phpstudy和wamp的区别有哪些?phpstudy和wamp哪个好?下面我们来总结一下。一:phpstudy好还是wamp好php的运行环境配置对于新手都是一件比较困难的事情,但是对于高手配置是一件繁琐的事情,个人…

哈夫曼树(最优二叉树)

1 用途 现在假如有一个需求, 把一个很长的字符串用二进制编码的形式存储, 要尽可能的占用较小空间, 那么应该怎么存储呢. 肯定是要确定每个字母的编码方法, 比如 001是A, 010是B等. 那么要怎么确定每个字符编成什么二进制码从而使得总长度最短? 一个根本思想是, 出现频率高的…

visual studio无法更新_VS Code Python 扩展 5 月更新

(给Python编程开发加星标,提升编程技能.)12 号,微软在官方博客发布了 VS Code 编辑器中 Python 扩展的 5 月更新,其中只有一个较为重要的特性:新增了浏览选择 Python 解释器的能力。增加这个功能,主要是为了让选择或变…

排序算法 --- 希尔排序

1 原理 希尔排序可以看作是对直接插入排序的优化. 直接插入是从前到后遍历数组, 每一个元素都往前移动到最合适的位置. 而希尔排序是利用间隔对数组进行分组, 然后再对每个小组进行子排序, 直到间隔为1. 2 具体步骤 首先要介绍一下间隔是什么. 间隔: 间隔是确定子分组的依据…

至强cpu型号列表_装机必看——CPU型号参数详解

装机必看——CPU型号参数详解——装机个人练习生-海在初步解了电脑构成后,我们DIY装机首先要看的就是如何选CPU,今天就带大家详细学习CPU的各类数据。说到CPU,我们先来介绍下生产CPU的两大公司——Intel和AMD。这两家公司相爱相杀接近50年了&…

多路平衡查找树 --- B(B-)树

1 简介 可以用阶数来描述B树, 一棵M阶B树代表着该B树最多有M个孩子节点. 如果M为2, 那么该B树就是一棵二叉搜索树. 一棵M阶B树具有以下性质: 1. 每个节点最多有M - 1个关键字. 跟普通的树不同, B树的关键字有多个. 2. 根节点最少可以只有一个关键字. 3. 非根节点至少有k个关…

python视窗编程_[PYTHON] 核心编程笔记(19.图形用户界面编程)

19.1 简介 19.1.1 什么是Tcl,Tk和Tkinter? 19.1.2 安装和使用Tkinter # apt-get install python-tk -y # python ------------------------------- Python 2.7.3 (default, Sep 26 2012, 21:51:14) [GCC 4.7.2] on linux2 Type "help", "copyright", &quo…

B+树操作方式

1 简介 B树与B树相似, 也存在不同. 可以理解为把所有元素都放在叶子节点, 索引B树化的树. B树的一些性质: 1. B树的节点分类: 内部节点(索引节点), 叶子节点. 如果只有根节点有元素, 那么其可以是内部节点也可以是叶子节点. 2. B树与B树最大的不同是内部节点不保存数据, 只…

java执行查询postgresql得到中文乱码_比这个夏天还要热的PostgreSQL数据库来啦!

什么是PostgreSQL?云数据库 PostgreSQL 是京东云基于开源的 PostgreSQL 10.6 版本构建的一款功能强大的企业级关系型数据库管理系统。PostgreSQL有“世界上可获得的最先进的开源数据库”之称,在过去20年的飞速发展中,该数据库已经广泛应用在G…

排序算法 --- 快速排序

1. 原理 首先, 在一个待排序序列中, 以第一个元素为基准, 让序列中所有的基准小的元素在该元素左边, 比其大的元素在其右边. 算法是一种原地算法, 首先把序列里面从基准开始的下一个元素一直到序列尾, 分成左右部分, 左边的都是小的, 右边的都是大的, 最后把基准跟中点交换一下…

python按列读取txt文件_如何使用pandas读取txt文件中指定的列(有无标题)

最近在倒腾一个txt文件,因为文件太大,所以给切割成了好几个小的文件,只有第一个文件有标题,从第二个开始就没有标题了。 我的需求是取出指定的列的数据,踩了些坑给研究出来了。 import pandas as pd # 我们的需求是 取…

C++的一些关键字

volatile 用volatile声明的变量, 是通知编译器, 该变量为时刻变化的变量, 编译时不要对其进行优化, 每次使用该变量的时候必须从其地址进行读取. (以下是个人理解)一般在多线程中的状态变量会被该关键字声明. 而标准使用场景是: 并行设备的硬件寄存器(如&#xf…

python doc_2019-2020年Python3中文教程完整版.doc

Python已经是3.1版本了,与时俱进更新教程.本文适合有Java编程经验的程序员快速熟悉Python本文程序在windows xppython3.1a1 测试通过.本文提到的idle指python shell,即安装python后你在菜单看到的IDLE(python gui)在idle里ctrln可以打开一个新窗口,输入源码后ctrls可以保存,f5运…

C++数据的一些注意事项

1 不同类型 1.1 静态变量 分类: 分为静态全局变量和静态局部变量 作用域: 需要注意静态全局变量也仅仅是在本文件中可用,除非加extern关键字。 内存分配位置 在全局区分配空间,初始值为0。 1.2 局部非静态变量 内存分配位…

python打包的exe如何免杀_如何使用Python进行Payload免杀

很多渗透工具都提供了权限维持的能力,如Metasploit、Empire和Cobalt Strike,但是都会被防病毒软件检测到恶意行为。在探讨一个权限维持技巧的时候,似乎越来越多的人关注的是,这个方式会不会被被杀软杀掉? 打造免杀的pa…

C++指针注意事项

指针占用空间 32位操作系统下指针占用四个字节的空间. 64位下占用8个字节. const 指针组合 const修饰指针 --- 常量指针 声明 const T *p xxx; 特点 指针指向可以修改, 但是指针指向的值不可以修改. 比如: int a 10; int b 20; const int *p &a; *p 20; …