百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

python字典操作全家桶,超全!!,字典相关操作都来这儿找

liuian 2025-02-19 12:55 29 浏览

python中字典相关操作,在实际开发中是必不可少的部分,除了它本身可以构造、存储数据外,它的结构和json类似,还可以互转。

在web开发、数据库查询结果集等都是以json或者字典形式存在,因此掌握字典相关操作是一个开发人员必备技能,下面的总结,按需获取,复制运行即可得出相应结果

1、创建字典(create)

 ====================基础创建=====================
dict_ = {}  # 直接创建空的字典--->最常用
dict_default = {"key1":"value1",'key2':'value2'}   # 赋值创建带默认值的字典--->创建默值字典最常用
dict_key = dict(key1="value1",key2="value2")   # 通过关键字dict创建--->使用较少
dict_fromkeys = dict.fromkeys(["key1","key2","key3"],"6666")    # fromkeys创建  使用较少

====================中高级创建======================
list_ = [("key1","value1"),("key2","value2")]   
dict_list = dict(list_)    # 列表嵌套二次元祖以及dict关键字创建,--->中等
dict_advance = { str(i):"value%s"%i for i in range(5) } # 字典解析创建字典--->常用

====================实际开发中常用构造================
list1,list2 = ["age","address","name"],[18,"重庆","张三"]
dict_advance2 = { key:value for key,value in zip(list1,list2) } # 字典解析创建字典(中高级用法)--->  常用
dict_zip = dict(zip(list1,list2))   # 最常用,代码短又简单,zip中防止可迭代对象即可,列表、元祖,字符串均可

执行上面代码后输出:
{}
{'key1': 'value1', 'key2': 'value2'}
{'key1': 'value1', 'key2': 'value2'}
{'key1': '6666', 'key2': '6666', 'key3': '6666'}
{'key1': 'value1', 'key2': 'value2'}
{'0': 'value0', '1': 'value1', '2': 'value2', '3': 'value3', '4': 'value4'}
{'age': 18, 'address': '重庆', 'name': '张三'}
{'age': 18, 'address': '重庆', 'name': '张三'}

2、字典新增元素(add)

dict_["age"] = 18       # dict[key] = value 方式新增--->最常用

value= {"name":"张三"}  # dict中update 方式新增--->常用
dict_.update(value)

3、字典删除元素(del)

dict_ = {'age': 18, 'address': '重庆', 'name': '张三'}

 =======================根据key 删除元素=================
del dict_["age"]    # 普通删除--->基本不用
dict_.pop("address")  #升级版删除--->最常用
dict_ = { key:value for key,value in dict_.items() if key != "name" }  # 字典解析删除---> 一般不使用,面试或装逼用
执行上面三句后输出:
{}
  =======================根据value 删除元素=================
dict_ = { key:value for key,value in dict_.items() if value != 18 }  # 通过字典解析删除,--->最常用,一般封装成方法使用
输出:
{ 'address': '重庆', 'name': '张三'}
  =======================删除、清空字典=================
dict_ = {'age': 18, 'address': '重庆', 'name': '张三'}
del  dict_       # 将字典从内存中删除,后面引用报错  --->不常用
dict_.clear()   # 清空字典中的所有key=value  --->不常用    

3、字典修改元素(modify)

dict_ = {'age': 18, 'address': '重庆', 'name': '张三'}

=======================修改字典值=================
dict_["age"] = 19     --->最常用
输出:
{'age': 19, 'address': '重庆', 'name': '张三'}
=======================修改字典key================
dict_.update({"newkey":dict_.pop("age")})   #封装成方法配合使用 --->常用
输出:
{'address': '重庆', 'name': '张三', 'newkey': 18}

4、字典相关元素获取(Find)

dict_ = {'age': 18, 'address': '重庆', 'name': '张三'}
=======================获取字典中所有key================
keys = list(dict_.keys())  #返回值是列表  --->常用
print(keys)
输出:
['age', 'address', 'name']
=======================获取字典中所有value================
keys = list(dict_.values())    #返回值是列表  --->常用
print(keys)
输出:
[18, '重庆', '张三']
=======================获取字典中所有key,value================
keys = list(dict_.items())  --->最常用
print(keys)
输出:
[('age', 18), ('address', '重庆'), ('name', '张三')]
======================根据key获取value===================
value1 = dict_["age"]  # key 不存在是会报错   --->常用
value2 = dict_.get("age",None)  # key 不存在时不会报错,并且可设置默认值,开发中最常用 --->常用
value3 = dict_.get("fff",None)  # 演示key不存在这种默认值 --->最常用,也是建议使用
value4 = "".join([ str(dict_[key]) for key in dict_.keys() if key=="age" ])  # 装逼写法,基础差的绝对看不懂
print(value1,value2,value3,value4)
输出:
18 18 None 18
========================根据value获取key===================
key1 = {value:key for key,value in dict_.items() }.get("重庆")  # 采用字典解析,key,value互换生成新的字典在获取值,一般封装成方法使用
key2 = [ key for key,value in dict_.items() if value=="重庆" ][0] # 采用列表解析获取key,一般封装成方法使用
key3 = "".join([ key[0] for key in dict_.items() if key[1] == "重庆" ]) # 采用列表解析获取key,一般封装成方法使用
print(key1,key2,key3)
输出:
address address address

5、字典排序(order)

======================根据key排序===================
  dict_ = {'15': 18, '12': '重庆', '11': '张三'}

new_dict1 = dict(sorted(dict_.items()))   #通过dict_.items()解析成元祖,在给元祖排序,在转换成字典
new_dict2 = {key:dict_[key]for key in sorted(dict_.keys())}   #通过dict_.keys()获取所以key,在key祖排序,字典解析生成字典
print(new_dict1)
print(new_dict2)
输出
{'11': '张三', '12': '重庆', '15': 18}
{'11': '张三', '12': '重庆', '15': 18}
======================根据value排序===================
  
  d = {'语文': 18, '数学': 88, '英语': 66,'物理': 22}

①new_order1 ={ va_ke[1]:va_ke[0] for va_ke in sorted( [(va,ke) for ke,va in sorted(d.items())])}
②new_order2 ={ va_ke[1]:va_ke[0] for va_ke in sorted(zip(d.values(),d.keys()))}
③new_order3 ={ key:va for key,va in sorted(d.items(),key=lambda items:items[1])}
print(new_order1)
print(new_order2)
print(new_order3)
输出:
{'语文': 18, '物理': 22, '英语': 66, '数学': 88}
{'语文': 18, '物理': 22, '英语': 66, '数学': 88}
{'语文': 18, '物理': 22, '英语': 66, '数学': 88}
解释:
①通过列表解析 [(va,ke) for ke,va in sorted(d.items())] 生成元祖(value,key)元祖,在给元祖排序,在用字典解析生成字典
②先通过(d.values(),d.keys())组装(value,key),在吧元祖压缩成一个列表,给列表排序,在用字典解析生成字典
③利用sorted可以指定排序关键字的原理,指定以value进行排序,先通过d.items()获取key,value的迭代对象,
然后通过key,指定排序关键字为value,sorted中指定排序关键字需要绑定函数,因此用lambda获取value

好了,相信你看了上面内容,慢慢练习,python的字典操作对你来说 so easy!,对了基本有关python字典相关的面试题你都能答出。

点赞收藏,忘记了就翻出来瞧瞧,慢慢的 它就是你的咯!

有看不懂的地方,,欢迎留言咨询,有问必答,相互学习,合作共赢~~~

相关推荐

教你把多个视频合并成一个视频的方法

一.情况介绍当你有一个m3u8文件和一个目录,目录中有连续的视频片段,这些片段可以连成一段完整的视频。m3u8文件打开后像这样:m3u8文件,可以理解为播放列表,里面是播放视频片段的顺序。视频片段像这...

零代码编程:用kimichat合并一个文件夹下的多个文件

一个文件夹里面有很多个srt字幕文件,如何借助kimichat来自动批量合并呢?在kimichat对话框中输入提示词:你是一个Python编程专家,完成如下的编程任务:这个文件夹:D:\downloa...

Java APT_java APT 生成代码

JavaAPT(AnnotationProcessingTool)是一种在Java编译阶段处理注解的工具。APT会在编译阶段扫描源代码中的注解,并根据这些注解生成代码、资源文件或其他输出,...

Unit Runtime:一键运行 AI 生成的代码,或许将成为你的复制 + 粘贴神器

在我们构建了UnitMesh架构之后,以及对应的demo之后,便着手于实现UnitMesh架构。于是,我们就继续开始UnitRuntime,以用于直接运行AI生成的代码。PS:...

挣脱臃肿的枷锁:为什么说Vert.x是Java开发者手中的一柄利剑?

如果你是一名Java开发者,那么你的职业生涯几乎无法避开Spring。它如同一位德高望重的老国王,统治着企业级应用开发的大片疆土。SpringBoot的约定大于配置、SpringCloud的微服务...

五年后,谷歌还在全力以赴发展 Kotlin

作者|FredericLardinois译者|Sambodhi策划|Tina自2017年谷歌I/O全球开发者大会上,谷歌首次宣布将Kotlin(JetBrains开发的Ja...

kotlin和java开发哪个好,优缺点对比

Kotlin和Java都是常见的编程语言,它们有各自的优缺点。Kotlin的优点:简洁:Kotlin程序相对于Java程序更简洁,可以减少代码量。安全:Kotlin在类型系统和空值安全...

移动端架构模式全景解析:从MVC到MVVM,如何选择最佳设计方案?

掌握不同架构模式的精髓,是构建可维护、可测试且高效移动应用的关键。在移动应用开发中,选择合适的软件架构模式对项目的可维护性、可测试性和团队协作效率至关重要。随着应用复杂度的增加,一个良好的架构能够帮助...

颜值非常高的XShell替代工具Termora,不一样的使用体验!

Termora是一款面向开发者和运维人员的跨平台SSH终端与文件管理工具,支持Windows、macOS及Linux系统,通过一体化界面简化远程服务器管理流程。其核心定位是解决多平台环境下远程连接、文...

预处理的底层原理和预处理编译运行异常的解决方案

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好![Mac-10.7.1LionIntel-based]Q:预处理到底干了什么事情?A:预处理,顾名思义,预先做的处理。源代码中...

为“架构”再建个模:如何用代码描述软件架构?

在架构治理平台ArchGuard中,为了实现对架构的治理,我们需要代码+模型描述所要处理的内容和数据。所以,在ArchGuard中,我们有了代码的模型、依赖的模型、变更的模型等,剩下的两个...

深度解析:Google Gemma 3n —— 移动优先的轻量多模态大模型

2025年6月,Google正式发布了Gemma3n,这是一款能够在2GB内存环境下运行的轻量级多模态大模型。它延续了Gemma家族的开源基因,同时在架构设计上大幅优化,目标是让...

比分网开发技术栈与功能详解_比分网有哪些

一、核心功能模块一个基本的比分网通常包含以下模块:首页/总览实时比分看板:滚动展示所有正在进行的比赛,包含比分、比赛时间、红黄牌等关键信息。热门赛事/焦点战:突出显示重要的、关注度高的比赛。赛事导航...

设计模式之-生成器_一键生成设计

一、【概念定义】——“分步构建复杂对象,隐藏创建细节”生成器模式(BuilderPattern):一种“分步构建型”创建型设计模式,它将一个复杂对象的构建与其表示分离,使得同样的构建过程可以创建...

构建第一个 Kotlin Android 应用_kotlin简介

第一步:安装AndroidStudio(推荐IDE)AndroidStudio是官方推荐的Android开发集成开发环境(IDE),内置对Kotlin的完整支持。1.下载And...