python数据类型之字典操作
Python字典是另一种可变容器模型,且可存储任意类型对象,如字符串、数字、元组等其他容器模型。
一、创建字典
字典由key和value成对组成。基本语法如下:
infos = {"name":"谢红","sex":"女","addr":"河南","age":"20"}
也可如此创建字典
dict1 = { 'abc': 456 }
dict2 = { 'abc': 123, 98.6: 37 }
注意:
每个key与value用冒号隔开(:),每对用逗号,每对用逗号分割,整体放在花括号中({})。
key必须独一无二,但value则不必。
value可以取任何数据类型,但必须是不可变的,如字符串,数或元组。
二、访问字典中的值
(1)使用get()方法访问字典中的值,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
print(infos.get("name")) # 打印key为name的value
print(infos.get("n"))#如果取不到这个key的话,就是None #以上运行结果是:
谢红
None
如果取不到key的话,就传入默认值:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
print(infos.get("n", 110)) # 如果取不到这个key的话,默认就是110 #以上运行结果是:
110
(2)直接使用key的值进行获取对应的value,如下:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
print(infos["age"]) #以上运行结果是:
20
三、向字典中增加key
(1)第一种方法,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
infos["phone"]=18888888888 #增加一个key
print(infos) #以上运行结果是:
{'name': '谢红', 'sex': '女', 'addr': '河南', 'age': '', 'phone': 18888888888}
使用这种方法,如果key存在的话,会修改原来key里面对应的值,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
infos["name"]="袁泉" #如果key存在的话,会修改原来key里面对应的值
print(infos) #以上运行结果是:
{'name': '袁泉', 'sex': '女', 'addr': '河南', 'age': ''}
(2)使用setdefault()方法增加key,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
infos["phone"]=18888888888 #增加一个key
infos.setdefault("xiaojinku","2000w") #增加xiaojinku对应的value是2000w
print(infos) #以上运行结果是:
{'name': '谢红', 'sex': '女', 'addr': '河南', 'age': '', 'phone': 18888888888, 'xiaojinku': '2000w'}
如果增加的key已经存在的话,不会修改原来的值,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
infos.setdefault("name","夏雨")#如果key存在的话,不会修改原来key里面的值
print(infos) #以上运行结果是:
{'name': '谢红', 'sex': '女', 'addr': '河南', 'age': ''}
四、删除字典中的值
(1)指定key来删除,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
infos.pop("name")# 指定key来删除
print(infos) #以上运行结果是:
{'sex': '女', 'addr': '河南', 'age': ''}
(2)使用popitem()方法随机删除一个key,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":""}
infos.popitem()#随机删除一个key
print(infos) #以上运行结果是:
{'name': '谢红', 'sex': '女', 'addr': '河南'} #结果随机删除了age
(3)使用del 方法指定key进行删除,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":"","phone":""}
del infos["phone"] #指定key来删除
print(infos) #以上运行结果是:
{'name': '谢红', 'sex': '女', 'addr': '河南', 'age': ''}
(4)使用clear()方法清空字典,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":"","phone":""}
infos.clear() #清空字典
print(infos) #以上运行结果是:
{}
五、字典的其他操作方法
(1)获取字典所有的value,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":"","phone":""}
print(infos.values()) #以上运行结果是:
dict_values(['谢红', '女', '河南', '', ''])
(2)获取到字典所有的key,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":"","phone":""}
print(infos.keys()) #获取到字典所有的key #以上运行结果是:
dict_keys(['name', 'sex', 'addr', 'age', 'phone'])
(3)获取到字典所有的k -v,例如:
infos = {"name":"谢红","sex":"女","addr":"河南","age":"","phone":""}
print(infos.items())# 获取到字典所有的k -v #以上运行结果是:
dict_items([('name', '谢红'), ('sex', '女'), ('addr', '河南'), ('age', ''), ('phone', '')])
(4)多维字典取值的方法,例如在下面实例中如果需要取到“qq”,具体是:
people = {
'李雷':{
'age':18,
'money':200000,
'clothes':'100套',
'hzp':'n多',
'shoes':['nike','addis','lv','chanle']
},
'韩梅梅':{
'金库':'2000w',
'house':['三环一套','4环2套'],
'cars': {
'japan':['普拉多','兰德酷路泽'],
'usa':['林肯','凯迪拉克','福特'],
'china':['五菱宏光','qq','红旗']
}
}
}
print(people['韩梅梅']["cars"]["china"][1]) #以上实例运行结果是:
(5)多维字典增加value,例如给韩梅梅的cars里的usa里增加一辆“牧马人”,如下:
people = {
'李雷':{
'age':18,
'money':200000,
'clothes':'100套',
'hzp':'n多',
'shoes':['nike','addis','lv','chanle']
},
'韩梅梅':{
'金库':'2000w',
'house':['三环一套','4环2套'],
'cars': {
'japan':['普拉多','兰德酷路泽'],
'usa':['林肯','凯迪拉克','福特'],
'china':['五菱宏光','qq','红旗']
}
}
}
people["韩梅梅"]["cars"]["usa"].append("牧马人")
print(people) #以上实例运行结果是:
{'李雷': {'age': 18,
'money': 200000,
'clothes': '100套',
'hzp': 'n多',
'shoes': ['nike', 'addis', 'lv', 'chanle']},
'韩梅梅': {'金库': '2000w',
'house': ['三环一套', '4环2套'],
'cars': {
'japan': ['普拉多', '兰德酷路泽'],
'usa': ['林肯', '凯迪拉克', '福特', '牧马人'],
'china': ['五菱宏光', 'qq', '红旗']}}}
(6)对字典进行循环,如果直接循环字典的话,那么循环的是字典的key,例如:
people = {
'李雷':{
'age':18,
'money':200000,
'clothes':'100套',
'hzp':'n多',
'shoes':['nike','addis','lv','chanle']
},
'韩梅梅':{
'金库':'2000w',
'house':['三环一套','4环2套'],
'cars': {
'japan':['普拉多','兰德酷路泽'],
'usa':['林肯','凯迪拉克','福特'],
'china':['五菱宏光','qq','红旗']
}
}
}
for i in people: #直接循环字典的话,那么循环的是字典的key
print(i) #以上实例运行结果是:
李雷
韩梅梅 #循环的结果只取到了key,即 李雷 和 韩梅梅
(7)可以用对应的key 和 value进行字典的循环,例如:
people = {
'李雷':{
'age':18,
'money':200000,
'clothes':'100套',
'hzp':'n多',
'shoes':['nike','addis','lv','chanle']
},
'韩梅梅':{
'金库':'2000w',
'house':['三环一套','4环2套'],
'cars': {
'japan':['普拉多','兰德酷路泽'],
'usa':['林肯','凯迪拉克','福特'],
'china':['五菱宏光','qq','红旗']
}
}
}
for k,v in people.items():
print(k,"====>",v) #以上实例运行结果是:
李雷 ====> {'age': 18, 'money': 200000, 'clothes': '100套', 'hzp': 'n多', 'shoes': ['nike', 'addis', 'lv', 'chanle']}
韩梅梅 ====> {'金库': '2000w', 'house': ['三环一套', '4环2套'], 'cars': {'japan': ['普拉多', '兰德酷路泽'], 'usa': ['林肯', '凯迪拉克', '福特'], 'china': ['五菱宏光', 'qq', '红旗']}}
六、将一个字典更新到另一个字典中,使用update()方法,如下:
a1 = {'姓名':'xiehong','籍贯':'河南',}
a2 = {'年龄':'保密'}
a1.update(a2)
print(a1) 结果是:{'姓名': 'xiehong', '籍贯': '河南', '年龄': '保密'}
python数据类型之字典操作的更多相关文章
- python数据类型:字典Dictionary
python数据类型:字典Dictionary 字典是一种可变容器模型,可以存储任意类型对象 键是唯一的,但是值不需要唯一 值可以取任何数据类型,但是键必须是不可变的,如字符串,数字,元组 创建字典: ...
- Python数据类型和数据操作
python数据类型有:int,float,string,boolean类型.其中string类型是不可变变量,用string定义的变量称为不可变变量,该变量的值不能修改. 下面介绍python中的l ...
- python数据类型之字典
字典定义 字典是一种 key-value 的数据类型,这点很重要,是区别使用列表和字典的依据. 语法格式: info = { 'stu1101': "Aaron", 'stu110 ...
- Python数据类型-6 字典
字典 Python的字典数据类型是基于hash散列算法实现的,采用键值对(key:value)的形式,根据key的值计算value的地址,具有非常快的查取和插入速度.但它是无序的,包含的元素个数不限, ...
- [Python Study Notes]字典操作
字典操作 a.增加 >>> info["stu1104"] = "abc" >>> info {'stu1102': 'x5 ...
- Python数据类型(字典和集合)
1.5 Dictionary(字典) 在Python中,字典用放在花括号{}中一系列键-值对表示.键和值之间用冒号分隔,键-值对之间用逗号分隔. 在字典中,你想存储多少个键-值对都可以.每个键都与一个 ...
- python学习之路-3 初始python数据类型以及文件操作
本篇涉及内容 set集合 函数 三元运算 文件操作 set集合 set是一个无序的且不重复的元素集合 1.创建set集合的方法 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...
- python 数据类型三 (字典)
一.字典的介绍 字典(dict)是python中唯一的一个映射类型,它是以{}括起来的键值对组成,在dict中key是唯一的,在保存的时候,根据key来计算出一个内存地址,然后将key-value保存 ...
- Python数据类型-04.字典
字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据 ------------ 完美的分割线 ------------- 1.字典引入 # 为何还要用字典?存放一个人的信 ...
随机推荐
- 【31.93%】【codeforces 670E】Correct Bracket Sequence Editor
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- JMeter FTP测试计划
为了演示测试目的,我们将使用公共可用的FTP位置,可以使用它来测试文件的下载. 您可以使用市场上现有的任何可用的演示FTP位置.我们使用URL下的FTP位置: https://dlptest.com/ ...
- python监控模块
pip install psutil 获取内存信息: >>> import psutil >>> mem = psutil.virtual_memory() #获取 ...
- 最小化centos7.4系统静默安装oracle12.2
一 orace简介 ORACLE(甲骨文)公司.Oracle Database (甲骨文数据库) 是一个具有对象和可扩展标记语言(XML)功能的关系数据库,提供的以分布式数据库为核心的一组软件产品,是 ...
- ansible批量部署mysql
1.1 将mysql软件包同步到客户端服务器,做安装前期准备 Ps:mysql安装包线拖到ansible服务端的/ansible/roles/mysql/files目录下 vim /ansible/r ...
- 20191107-8 beta week 2/2 Scrum立会报告+燃尽图 07
此作业要求参见 http://edu.cnblogs.com/campus/nenu/2019fall/homework/9960 小组名称:“组长”组 组长:杨天宇 组员:魏新,罗杨美慧,王歆瑶,梅 ...
- QTableView 控件的简单使用
QTableView类提供了一个表视图的默认模型/视图实现. 一个QTableView实现一个表视图,它显示来自一个模型的项目.这个类用于提供以前由QTable类提供的标准表,但是使用Qt的模型/视图 ...
- Python 植物大战僵尸代码实现: 图片加载和显示切换
游戏介绍以前很火的植物大战僵尸游戏, 本想在网上找个python版本游戏学习下,无奈没有发现比较完整的,那就自己来写一个把.图片资源是从github上下载的,因为图片资源有限,只能实现几种植物和僵尸. ...
- 傅立叶变换—FFT
FFT(快速傅立叶变换)使用“分而治之”的策略来计算一个n阶多项式的n阶DFT系数的值.定义n为2的整数幂数,为了计算一个n阶多项式f(x),算法定义了连个新的n/2阶多项式,函数f[0](x)包含了 ...
- MAVEN配置及Spring Tool Suite的Maven配置
1.下载Maven http://maven.apache.org/download.cgi 如图点击下载即可 2.Maven配置 2.1配置本地仓库 创建目录maven-repository如图所示 ...