首页 / 知识
Python字典之通过序列生成字典
2023-11-12 13:39:00
我们将下面的python序列转换为dict类型。
lst=[('a',1),('b',2),('c',3)]
普通的写法:
fork,vinlst:dic[k]=v
更pythonic的写法:
利用字典推导式快速生成字典。
{k:vfork,vinlst}
key的默认值
当指定key不存在时,将value设置为0。
普通的写法:
ifkeynotindct:dct[key]=0
pythonic的写法:
dct[key]=dct.get(key,0)
交换key与value
普通的写法:
dic={'Python':1,'Java':2}new_dic={}fork,vindic.items():new_dic[v]=k
更pythonic的写法:
dic={'Python':1,'Java':2}new_dic={v:kfork,vindic.items()}
序列修改和初始化
示例数据
lst=[('a',1),('b',2),('c',3)]dic={'a':[0]}
如果我们需要根据lst来更新dic中的数据,当key存在,则将value添加到原序列末尾,否则初始化value并用序列保存。
普通的写法:
forkey,valueinlst:ifkeyindic:dic[key].append(value)else:dic[key]=[value]
更pythonic的写法:
for(key,value)inlst:group=dic.setdefault(key,[])group.append(value)#dic:{'a':[0,1],'b':[2],'c':[3]}
setdefault(key,default)会先判断key是否存在,存在则返回dct[key],不存在则把dct[key]设为[]并返回。
key,items的集合运算
如果我们现在需要获取两个字典的key相交的部分的映射信息。
普通的写法:
dic1={'Python':1,'Java':2,'C':3}dic2={'Python':3,'Java':2,'C++':1}new_dic={}fork,vindic1.items():ifkindic2.keys():new_dic[k]=vprint(new_dic)#{'Python':1,'Java':2}
更pythonic的写法:
dic1={'Python':1,'Java':2,'C':3}dic2={'Python':3,'Java':2,'C++':1}print({k:dic1[k]forkindic1.keys()&dic2.keys()})#{'Python':1,'Java':2}
这里的dic1.keys()&dic2.keys()用到的就是keys()进行集合运算,items()同样可以进行集合运算。
如果现在我们要获取两个字典中key,value完全相同的部分。
dic1={'Python':1,'Java':2,'C':3}dic2={'Python':3,'Java':2,'C++':1}print(dic1.items()&dic2.items())#{('Java',2)}
灵活运用keys,items()集合运算的特性,可以快速提取我们想要的内容。
按key或value对字典排序
使用sorted()函数快速实现对key或value的排序。
dic={'a':2,'b':1,'c':3,'d':0}lst1=sorted(dic.items(),key=lambdax:x[0],reverse=False)#[('a',2),('b',1),('c',3),('d',0)]lst2=sorted(dic.items(),key=lambdax:x[1],reverse=False)#[('d',0),('b',1),('a',2),('c',3)]print('按照键降序:',{key:valueforkey,valueinlst1})print('按照值降序:',{key:valueforkey,valueinlst2})#按照键降序:{'a':2,'b':1,'c':3,'d':0}#按照值降序:{'d':0,'b':1,'a':2,'c':3}
多个字典排序
如果一个序列中包含多个字典,现在要根据条件对这些字典继续排序。同样可以使用sorted()函数来实现。
dict_list=[{'letter':'B','number':'2'},{'letter':'A','number':'3'},{'letter':'B','number':'1'}]#按letter排序print(sorted(dict_list,key=lambdadic:dic['letter']))#按letter,number排序print(sorted(dict_list,key=lambdadic:(dic['letter'],dic['number'])))#[{'letter':'A','number':'3'},{'letter':'B','number':'2'},{'letter':'B','number':'1'}]#[{'letter':'A','number':'3'},{'letter':'B','number':'1'},{'letter':'B','number':'2'}]
当然,如果你知道itemgetter()的话,上面的代码就可以改变一下,执行速度会更快。
fromoperatorimportitemgetterprint(sorted(dict_listkey=itemgetter('letter')))print(sorted(dict_list,key=itemgetter('letter','number')))
itemgetter()获取的不是值,而是定义了一个函数,通过该函数作用到目标对象上
以上内容为大家介绍了Python字典之通过序列生成字典,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注我们http://www.mobiletrain.org/
最新内容
相关内容
linux清空信息的命令?
linux清空信息的命令?,信息,系统,设备,情况,命令,暂停,状态,发行,数字,文件,Linux文件系统操作命令1、df命令:用于显示文件系统的磁盘空间使用linux命令行连数据库?
linux命令行连数据库?,地址,服务,信息,名字,数据库,密码,网络,一致,软件,系统,linux怎么连接mongodb数据库1、在这里使用的是MongoVUE进行连接linux命令代码怎么看?
linux命令代码怎么看?,时间,系统,代码,命令,状态,工具,情况,电脑,实时,基础,linux查看系统命令是什么有的,Linux中有多个命令可以用于查看文件怎么把数据库导入navicat?
怎么把数据库导入navicat?,软件,信息,密码,管理,数据库,服务,电脑,按钮,类型,文件,Navicat是一个强大的数据库管理工具,它可以连接和管理多种数比较好用的Python代码编辑器
比较好用的Python代码编辑器,代码,平台,环境,培训,教育,设计,数据,办公,人员,分析,Python是一款非常简单的编程语言,其功能使用起来都十分方便pycharm无法输入代码?
pycharm无法输入代码?,代码,环境,工具,分析,输入法,键盘,性能,计算机,问题,版本,PyCharm是一款Python语言开发的集成开发环境(IDE),它是许多Pytho深入理解python函数传参机制
深入理解python函数传参机制,培训,对象,函数,变量,类型,复本,下面,操作,机制,内存,首先需要申明的一点是,python里是没有像C和C++里那样按值传大学生报名Python培训课程的好处是
大学生报名Python培训课程的好处是什么?,培训,企业,社会,项目,行业,工作,时间,技术,都会,素养,一、报名学习前沿技术在IT行业,技术在不断变化和python代码的规范建议
python代码的规范建议,代码,异常,二元,设计,数字,下降,一致,培训,标准,空行,1.一致性的建议打破一条既定规则的两个好理由当应用这个规则将导线上Python培训和线下有什么不同?
线上Python培训和线下有什么不同?,培训,基础,实战,电脑,项目,教育,时间,地方,初级,技术,学习互联网技术的人越来越多,很多机构都采取线上和线下报名Python培训选择哪种方式比较好
报名Python培训选择哪种方式比较好?,培训,工作,基础,时间,情况,在线,最划算,环境,系统,方式,Python不仅是一种高级的编程语言,而且还是一种应用Python数据分析有哪些重要的库?
Python数据分析有哪些重要的库?,数据,分析,标准,庞大,通用,平台,培训,工具,基础,灵活,众所周知,有很多编程语言都可以应用于数据分析领域,但Pyth