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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ICP证书_dwcc2018怎么用

    ICP证书_dwcc2018怎么用输入44 21 2 4 84 0100 99 98 972 210000 100005 30 0 0 0 1696RichmanImpossible代码#include<bits/stdc++.h>using namespace std;typedef long long ll;const int N = 1e5 + 10;int a[N];int main(){ int T; cin>>T; while(T -..

    2022年8月11日
    6
  • JS中鼠标拖拽div(2)(setCapture()方法和releaseCapture()方法)

    JS中鼠标拖拽div(2)(setCapture()方法和releaseCapture()方法)接着鼠标拖拽div(1)解决问题,当在拖拽事件所在的页面按下键盘的ctrl+A全选后,再去拖拽div,浏览器会默认去搜索网页中的内容,拖拽功能就会失效,(搜索网页内容是浏览器的默认行为,所以要想不发生这种情况,就得将其取消,是谁执行之后触发了浏览器的默认行为,就在谁里面returnfalse即可取消浏览器的默认行为,但这种方式ie8及以下的版本不支持。)在ie8及以下版本浏览器中,如果调用了元素的setCapture()方法,那么点击任何事物都会来执行这个元素绑定的响应函数。例如:btn.oncl

    2022年5月8日
    53
  • offsetHeight, clientHeight与scrollHeight的区别

    offsetHeight, clientHeight与scrollHeight的区别在网上搜了一下,结论非常笼统,讲IE从不讲版本,因此自己做了测试并上传结论。以下结论皆是在标准模式下测试通过的,没有测试quirk模式。clientHeight大部分浏览器对clientHeight都没有什么异议,都认为是内容可视区域的高度,也就是说页面浏览器中可以看到内容的这个区域的高度,即然是指可看到内容的区域,滚动条不算在内。但要注意padding是算在内。其计算方式

    2022年7月23日
    12
  • Go语言代理proxy设置「建议收藏」

    Go语言代理proxy设置「建议收藏」关于GoproxyGOPROXY由于国内的网络环境,我们可以通过配置GOPROXY避免DNS污染导致的模块拉取缓慢或失败的问题,加速你的构建代理链接阿里云GoModule代理仓库服务Goproxy中国配置方法打开你的终端并执行:$goenv-wGOPROXY=https://goproxy.cn,direct完成。macOS或Linux打开你的终端并执行:$exportGOPROXY=https://goproxy.cn或者$echo“exportG

    2022年7月26日
    8
  • 测试15

    测试15无意中发现了一个巨牛的人工智能教程,忍不住分享一下给大家。教程不仅是零基础,通俗易懂,而且非常风趣幽默,像看小说一样!觉得太牛了,所以分享给大家。点这里可以跳转到教程。HTTP的接口测试工具有很多,

    2022年7月3日
    23
  • OpenCV人脸识别的原理 .

    OpenCV人脸识别的原理 .在之前讲到的人脸测试后,提取出人脸来,并且保存下来,以供训练或识别是用,提取人脸的代码如下:voidGetImageRect(IplImage*orgImage,CvRectrectInImage,IplImage*imgRect,doublescale){ //从图像orgImage中提取一块(rectInImage)子图像imgRect IplImage*res

    2022年5月9日
    42

发表回复

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

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