python中的字典操作及字典函数
作者:wiz_333 发布时间:2023-02-06 05:17:42
标签:python,字典
字典
dict_fruit = {'apple':'苹果','banana':'香蕉','cherry':'樱桃','avocado':'牛油果','watermelon':'西瓜'}
字典的操作
#字典的遍历方式
#默认遍历(遍历key)
for value in dict_fruit:
print(value)
'''''
遍历出的值:
watermelon
apple
cherry
avocado
banana
'''
#使用key遍历(与默认遍历一样)
for key in dict_fruit.keys():
print(key)
'''''
遍历出的值:
watermelon
apple
cherry
avocado
banana
'''
#使用value遍历
for value in dict_fruit.values():
print(value)
'''''
遍历出的值:
苹果
牛油果
香蕉
西瓜
樱桃
'''
#使用key,value遍历
for key,value in dict_fruit.items():
print(key+'--->'+value)
'''''
遍历出的值:
avocado--->牛油果
apple--->苹果
banana--->香蕉
cherry--->樱桃
watermelon--->西瓜
'''
#创建字典
#使用dict()
res = dict(brand = '品牌',size='尺码',color='颜色')
print(res,type(res))
'''''
res结果:
{'size': '尺码', 'brand': '品牌', 'color': '颜色'} <class 'dict'>
'''
#使用zip()和dict()
keys = ['1','2','3','4','5']
values = [1,2,3,4,5]
res = dict(zip(keys,values))
print(res,type(res))
'''''
res结果:
{'3': 3, '4': 4, '1': 1, '2': 2, '5': 5} <class 'dict'>
'''
#字典的推导式
res = {k+'的中文是'+v for k,v in dict_fruit.items()}
print(res)
'''''
res结果:
{'watermelon的中文是西瓜', 'avocado的中文是牛油果', 'banana的中文是香蕉', 'cherry的中文是樱桃', 'apple的中文是苹果'}
'''
字典的函数
#清空字典
test1 = {1:'1'}
test1.clear()
print(test1)
'''''
test1结果:
{}
'''
#复制字典(复制成一个新字典)
test2 = {2:'2'}
test2_copy = test2.copy()
print(test2_copy)
'''''
test2结果:
{2: '2'}
'''
#使用指定的key和value制作一个字典
list_test = ['a','b','c']
test3 = {}.fromkeys(list_test,'ojbk')
print(test3)
'''''
test3结果:
{'a': 'ojbk', 'b': 'ojbk', 'c': 'ojbk'}
'''
#将一个字典转化为二级容器(中间容器)
res = dict_fruit.items()
print(res,type(res))
'''''
res结果:
dict_items([('avocado', '牛油果'), ('apple', '苹果'), ('banana', '香蕉'), ('watermelon', '西瓜'), ('cherry', '樱桃')]) <class 'dict_items'>
'''
#将字典的key组成新的容器
res = dict_fruit.keys()
print(res,type(res))
'''''
res结果:
dict_keys(['watermelon', 'cherry', 'avocado', 'apple', 'banana']) <class 'dict_keys'>
'''
#将字典的value组成新的容器
res = dict_fruit.values()
print(res,type(res))
'''''
res结果:
dict_values(['牛油果', '香蕉', '樱桃', '苹果', '西瓜']) <class 'dict_values'>
'''
#根据key删除字典中的数据
test4 = {1:'1',2:'2',3:'3'}
test4.pop(2)
print(test4)
'''''
test4结果:
{1: '1', 3: '3'}
'''
#依次弹出(删除)字典中的数据
test5 = {1:'1',2:'2',3:'3',4:'4',5:'5'}
test5.popitem()
print(test5)
test5.popitem()
print(test5)
test5.popitem()
print(test5)
'''''
test5依次结果:
{2: '2', 3: '3', 4: '4', 5: '5'}
{3: '3', 4: '4', 5: '5'}
{4: '4', 5: '5'}
'''
#更新dict中的数据(更新一个不存在的key时,可用于添加新数据)
test6 = {'super':'Eric','ssuper':'Cbabe','sssuper':'Gogo','supreme':'wiz333'}
#更新数据
test6.update(super='Eric-LPL')
print(test6)
#添加数据
test6.update(niceboy='Bigmao')
print(test6)
'''''
test6依次结果:
{'ssuper': 'Cbabe', 'supreme': 'wiz333', 'sssuper': 'Gogo', 'super': 'Eric-LPL'}
{'ssuper': 'Cbabe', 'supreme': 'wiz333', 'niceboy': 'Bigmao', 'sssuper': 'Gogo', 'super': 'Eric-LPL'}
'''
#获取dict中的数据(使用key获取)
test7 = {1:'1',2:'2',3:'3',4:'4',5:'5'}
res = test7.get(1)
print(res,type(res))
'''''
test7结果:
1 <class 'str'>
'''
#给dict添加数据(setdefault,不能用于更新数据)
test8 = {1:'1',2:'2',3:'3',4:'4',5:'5'}
test8.setdefault(6,'6')
print(test8)
'''''
test8结果:
{1: '1', 2: '2', 3: '3', 4: '4', 5: '5', 6: '6'}
'''
总结
以上所述是小编给大家介绍的python中的字典操作及字典函数网站的支持!
来源:http://blog.csdn.net/wizblack/article/details/78950071


猜你喜欢
- 昨天第一次用python画圆,当时并没有安装numpy库(导入数据包)和matplotlib库(导入图形包),于是尝试用pip安装库首先,我
- 楼主在做公司项目的时候遇到url重定向的问题,因此上网简单查找,作出如下结果由于使用的是语言是python所以以下是python的简单解决方
- 众所周知,凡是用 FrontPage 做的网页里面都有类似这样的标记:<META content="Microso
- 第一类:对于下面的这些option的可选参数,value应该被设置一个bool类型的值:选项可选value值备注CURLOPT_AUTORE
- 本文实例讲述了Python爬虫PyQuery库基本用法。分享给大家供大家参考,具体如下:PyQuery库也是一个非常强大又灵活的网页解析库,
- 常见的误解有: 1. 只用 ado.net ,无法进行动态 SQL 拼接。 2. 有几个动态参数,代码的重复量就成了这些参数的不同数量的组合
- Python数据库编程之pymysql学习之前务必安装MySQL并已启动相关服务。一、pymsql的安装在python3的环境中直接使用以下
- 前言在日常开发中,我们往往会将 JSON 解析成对应的结构体,反之也会将结构体转成 JSON。接下来本文会通过 JSON 包的两个函数,来介
- JSON Schema是一个用于验证JSON数据结构的强大工具, 我查看并学习了JSON Schema的官方文档, 做了详细的记录, 分享一
- CentOS mysql安装还是很常用的软件,我就学习如何CentOS mysql安装,在这里拿出来和大家分享一下,希望对大家有用。Cent
- 一、什么是框架框架的本质就是一个socket服务,可以完成不同主机之间的通信。它是一个半成品的项目,其中可能已经封装好了基本的功能,比如路由
- --取得所有数据库名 包括系统数据库 --SELECT name FROM master.dbo.sysdatabases --取得所有非系
- sysdate+(5/24/60/60) 在系统时间基础上延迟5秒 sysdate+5/24/60 在系统时间基础上延迟5分钟 sysdat
- 二分类或分类问题,网络输出为二维矩阵:批次x几分类,最大的为当前分类,标签为one-hot型的二维矩阵:批次x几分类计算百分比有numpy和
- package dao;import org.hibernate.HibernateException;import org.hiberna
- status = show status like ‘%%' [例:show status like 'Com_select
- 装饰器模式在以下场景中被广泛应用:动态地向对象添加职责或行为,而不需要更改对象的代码。例如,可以通过装饰器模式来实现日志记录、性能分析、缓存
- 前言mysql中的explain命令可以用来查看sql语句是否使用了索引,用了什么索引,有没有做全表扫描。可以帮助我们优化查询语句。expl
- 前言大家好,我叫善念。这是我的第二篇博客,也是第一篇技术博客,希望大家多多支持,让我更加有动力去更新一些python爬虫类的案例教程。开始确
- 如下所示:# 创建一个空的 DataFramedf_empty = pd.DataFrame()#或者df_empty = pd.DataF