python字典的操作

python字典的操作python 字典操作字典 1 花括号定义的 2 python 内置的数据结构之一 与列表一样是一个可变序列 3 以键值对 冒号前的叫键 冒号后的叫值 的方式存储数据 字典是一个无序的序列 即是通过 hash 函数计算而来 4 元素之前用逗号分隔 5 键具有唯一性 不可重复 当键重复的时候不会报错 而是左边的键会被右边的键所覆盖字典实现原理 类似于查字典 不过 python 中的字典是根据 ke

''' python字典操作 字典:(1)花括号定义的, (2)python内置的数据结构之一,与列表一样是一个可变序列 (3)以键值对(冒号前的叫键,冒号后的叫值)的方式存储数据,字典是一个无序的序列,即是通过 hash()函数计算而来( 4)元素之前用逗号分隔 (5)键具有唯一性,不可重复。当键重复的时候不会报错,而是左边的键会被右边的键所覆盖 字典实现原理: 类似于查字典,不过python中的字典是根据key查找value所在的位置 通过hash(key) 找到这个key的值 .字典的创建 1.最常用的方式:使用花括号 eg: sheng = { 9:98 , "李四":97 , "王五":96 , ......} 2.使用内置函数dict() eg: sheng = dict(name='jick',age=20) #注意 这里创建是用的等号 3.创建空字典 eg: sheng = {} .获取字典中的元素 1.使用[key] 语法格式: 字典名[key] eg: sheng = {"张三":98,"李四":97,"王五":96,"铁牛":95} print(sheng["张三"]) 输出为:98 2.使用get()方法 语法格式: 字典名.get(key) eg: sheng = dict(name="圣",age=20,gender="男") print(sheng.get('name')) 3.俩种方法的区别 使用第一种方法获取字典中的元素,如果没有这个键,会报错KeyError。 使用第二种方法获取字典中的元素,如果没有这个键,不会报错,而是显示None。 4.len(字典名) # 将会返回字典子键的个数 .字典的增、删、改操作 1.判断字典中是否存在这个键 语法格式1: key in 字典名 语法格式2: key not in 字典名 返回值是逻辑值true 或者 false 2.删除字典中元素 语法格式: del 字典名[key] eg: sheng = dict(name="圣",age=20,gender="男") print("原字典内容:",sheng) del sheng["gender"] print("删除后的内容:",sheng) 输出: 原字典内容: {'name': '圣', 'age': 20, 'gender': '男'} 删除后的内容: {'name': '圣', 'age': 20} 3.清空字典中元素 语法格式: 字典名.clear() 4.新增字典中元素 语法格式: 字典名[key] = 值 eg: sheng = dict(name="圣",age=20,gender="男") print("原字典内容:",sheng) sheng["xingbie"] = "nv" print("新增后的内容",sheng) 输出: 原字典内容: {'name': '圣', 'age': 20, 'gender': '男'} 新增后的内容 {'name': '圣', 'age': 20, 'gender': '男', 'xingbie': 'nv'} 5.修改字典中键的值 语法格式: 字典名[key] = 值 eg: sheng = dict(name="圣",age=20,gender="男") print("原字典内容:",sheng) sheng["name"] = "潘" print("修改后的字典内容:",sheng) 输出为: 原字典内容: {'name': '圣', 'age': 20, 'gender': '男'} 修改后的字典内容: {'name': '潘', 'age': 20, 'gender': '男'} 6.更新字典内容 语法格式: 字典名1.update(字典名2) 将字典名2 中的元素添加到字典名1 中,如果key相同则会被字典名2 中的覆盖 eg: sheng = dict(name="圣",age=20,gender="男") print(sheng) shu = dict(name="冷",年龄=19,性别="男") sheng.update(shu) print(sheng) print(shu) 输出: {'name': '圣', 'age': 20, 'gender': '男'} {'name': '冷', 'age': 20, 'gender': '男', '年龄': 19, '性别': '男'} {'name': '冷', '年龄': 19, '性别': '男'} .获取字典视图的方法 1.获取字典中的键 语法格式: 字典名.keys() eg: sheng = dict(name="圣",age=20,gender="男") print(sheng.keys()) 输出: dict_keys(['name', 'age', 'gender']) 还可以将字典视图转换成列表:先将获取的键存放到一个变量,然后再list(变量). eg: sheng = dict(name="圣",age=20,gender="男") print(sheng.keys()) shu = sheng.keys() print(list(shu)) 输出: dict_keys(['name', 'age', 'gender']) ['name', 'age', 'gender'] 2.获取字典中所有的值 语法格式: 字典名.values() eg: sheng = dict(name="圣",age=20,gender="男") print(sheng.values()) 依然也可以将值转换成列表, eg: sheng = dict(name="圣",age=20,gender="男") print(sheng.values()) shu = sheng.values() print(list(shu)) 3.获取字典里的键和值 语法格式: 字典名.itmes() eg: sheng = dict(name="圣",age=20,gender="男") print(sheng.items()) 输出: dict_items([('name', '圣'), ('age', 20), ('gender', '男')]) #依然也可以将值转换成列表 eg: sheng = dict(name="圣",age=20,gender="男") print(sheng.items()) shu = sheng.items() print(list(shu)) 输出: dict_items([('name', '圣'), ('age', 20), ('gender', '男')]) [('name', '圣'), ('age', 20), ('gender', '男')] .字典元素的遍历(通过for in 循环来操作) eg : sheng = dict(name="圣",age=20,gender="男") for i in sheng.items(): 如果in后面只是一个字典名 那么将只会输出字典中所有的键 print(i) 输出:('name', '圣') ('age', 20) ('gender', '男') .字典生成式(两个列表:一个列表作为键,另一个列表作为值) 通过zip()函数对两个列表进行打包 语法格式: {item.upper:price for item,price in zip(列表1,列表2)} item后面的.upper()是将键转成为英文大写 eg: a = ["姓名","xingbie","nianling"] b = ["sheng","男",20] c = {item.upper():price for item,price in zip(a,b)} print(c) 输出: {'姓名': 'sheng', 'XINGBIE': '男', 'NIANLING': 20} '''
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233697.html原文链接:https://javaforall.net

(0)
上一篇 2025年6月28日 下午5:01
下一篇 2025年6月28日 下午5:22


相关推荐

  • 泛型(泛型擦除)【java基础—-泛型】

    泛型(泛型擦除)【java基础—-泛型】泛型(泛型擦除)【java基础—-泛型】

    2022年10月19日
    19
  • Mysql数据库课程设计

    Mysql数据库课程设计Hello小伙伴们,大家好,我是楠橘星!!今天给大家分享一下使用javafx编写的前端的Mysql数据库课程设计题库与试卷生成系统!废话不多说了,直接上截图,希望对大家有所帮助!(建议拿来参考不建议直接CV哦!)1.系统需求分析1-1、功能分析通过深入细致的调查,多方面搜集资料,以及实地考察等方法,经过总结研究,总结出了试卷生成系统的的基本的业务功能,详细如下:学生信息维护:主要完成学生的学号、班级、考试信息等操作。教师信息维护:主要是教师信息的添加、修改和删除等操作。题库信息维护

    2022年5月19日
    59
  • QTableWidget_qt tabwidget

    QTableWidget_qt tabwidgetQTabWidget#include”tab.h”Tab::Tab(QWidget*parent) :QMainWindow(parent){ ui.setupUi(this); tabWidget=newQTabWidget(); tabWidget->setParent(this); //新建第一个页面的部件 QWidget*widget=new…

    2025年12月8日
    7
  • PyQt5高级界面控件之QThread(十二)

    PyQt5高级界面控件之QThread(十二)QThread前言QThread是Qt线程类中最核心的底层类。由于PyQt的跨平台特性,QTHread要隐藏所有与平台相关的代码要使用QThread开始一个线程,可以创建它的一个子类,然后覆盖器其QThread.run()函数classThread(QThread):def__init__(self):super(Thread,self)._…

    2022年5月28日
    40
  • phpstrom 3.3激活码_通用破解码

    phpstrom 3.3激活码_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    37
  • c语言 无锁编程,无锁编程与有锁编程的效率总结、无锁队列的实现(c语言)「建议收藏」

    c语言 无锁编程,无锁编程与有锁编程的效率总结、无锁队列的实现(c语言)「建议收藏」1.无锁编程与有锁编程的效率无锁编程,即通过CAS原子操作去控制线程的同步。如果你还不知道什么使CAS原子操作,建议先去查看相关资料,这一方面的资料网络上有很多。CAS实现的是硬件级的互斥,在线程低并发的情况下,其性能比普通互斥锁高效,但是当线程高并发的时候,硬件级互斥引入的代价与应用层的锁竞争产生的代价同样都是很大的。这时普通锁编程其实是优于无锁编程的。硬件级原子操作使应用层的操作变慢,而且无法…

    2022年5月2日
    46

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号