day 05 字典,字典嵌套
字典:
1、列表如果存储大量数据,查询速度相对慢一些
2、列表存储的数据,一般没有什么关联性
针对以上原因,python提供了一个基础数据类型,dict 字典
数据类型的分类 :
容器型数据类型:list, tupel,dict,set
非容器型数据类型: str , bool , int
可变(不可哈希)的数据类型: list, dict,set
不可变(可哈希)的数据类型:str , int, bool, tuple
{‘name’:‘alex’} 以键值对形式存储的数据类型
1、 字典的键必须是不可变的数据类型,唯一的,不重复。 重复则后面的覆盖之前的
字典的值可以是任何数据类型(对象)
2、字典的查询速度非常快
3、字典在python3.5之前是无序的,单是3.6优化机制,字典会按照创建字典之处的数据排列
4、字典可以存储大量的关联性数据
# 字典嵌套字典列表
dic = {'name': 'alex','python3期':['小潘','春哥', '二师兄'],
'太白':{
'name':'太白金星',
'id': 1306546743423,
'phone': 1358225xxxx,
'sex': '男'
}
}
2、字典的增删改查
增: 有则覆盖,无责添加
dic['keys'] = ' value '
dic = {'name': 'barry', 'age': 18, 'sex': 'man'}
dic['high'] = 179
print(dic) # {'name': 'barry', 'age': 18, 'sex': 'man', 'high': 179}
dic['name'] = 'echo'
print(dic) #{'name': 'echo', 'age': 18, 'sex': 'man', 'high': 179}
setdefault 有则不变,无责添加
dic.setdefault('KEYS', 'value') 如果不填value,责为None
dic = {'name': 'barry', 'age': 18, 'sex': 'man'}
dic.setdefault('high') #{'name': 'barry', 'age': 18, 'sex': 'man', 'high': None}
print(dic)
dic.setdefault('name', 'echo')
print(dic) #{'name': 'barry', 'age': 18, 'sex': 'man', 'high': None}
删:
1、pop 通过键删除对应值
dic.pop('key') dic.pop(' key' , ' 没有这个键 ‘) 如果没有健,可以自定义返回值
dic = {'name': 'barry', 'age': 18, 'sex': 'man'}
dic.pop('name1', '没有该键') # 没有键则返回自定义的值
print(dic)
2、clear 清空列表值,保留列表
dic = {'name': 'barry', 'age': 18, 'sex': 'man'}
dic.clear()
print(dic)
3、popitem 删除最后一个键值对 (3.5及以前版本,是随机删除。因为3.5之前版本字典是无序)
dic = {'name': 'barry', 'age': 18, 'sex': 'man'}
dic.popitem() # 3.5之前是随机删除,3.6删除最后一个键值对
print(dic) # {'name': 'barry', 'age': 18}
4、del
dic = {'name': 'barry', 'age': 18, 'sex': 'man'}
del dic # 删除整个字典
一次只能删除一个键,没有则报错。还是用pop好一点
dic = {'name': 'barry', 'age': 18, 'sex': 'man'}
del dic['name1'] # 一次只能删除一个键,没有则报错。还是用pop好一点
print(dic)
改:
dic[' key '] = ' value '
dic = {'name': 'barry', 'age': 18}
dic['age'] = 14
print(dic) # {'name': 'barry', 'age': 14}
dic['age', 'name'] = 14, 'alex'
print(dic) # {'name': 'barry', 'age': 14, ('age', 'name'): (14, 'alex')} 把两个键当一个元组,组合成一个键
update 有两种方式:
1、 把dic1 update到 dic2
dic1 = {"name": "jin", "age": 18, "sex":"male"}
dic2 = {"name": "alex","weight": 75}
dic2.update(dic1) # 将dic1字典中的键值对覆盖添加到dic2中,dic1不变。
print(dic1) # {'name': 'jin', 'age': 18, 'sex': 'male'}
print(dic2) # {'name': 'jin', 'weight': 75, 'age': 18, 'sex': 'male'}
2、dic.update(weight=150, high=175)
dic1 = {"name": "jin", "age": 18}
dic1.update(weight=150, higi=178) # key不在dic1中,则增加
print(dic1) # {'name': 'jin', 'age': 18, 'weight': 150, 'higi': 178}
dic1.update(name=150) # key在dic1中,则修改
print(dic1) # {'name': 150, 'age': 18, 'weight': 150, 'higi': 178}
查:
1、按照键查对应的值
print(dic['name'])
print(dic['name1']) # 没有此键会报错 2、用gat查 ,不会报错
dic = {"name": "jin", "age": 18}
ret = dic.get('age') # 打印 18
ret = dic.get('age1') # 打印None
ret = dic.get('age1','没有此键') #打印 '没有此键'
print(ret)
3、直接循环字典,获取所有key值
for i in dic:
print(i)
4、 dic.keys() , dic.values() dic.item()
dic = {"name": "jin", "age": 18}
# dic.keys() dic.values() dic.items()
# 上面三个都是返回一个类似于列表的容器的特殊数据类型。
print(dic.keys())
for key in dic.keys():
print(key) print(dic.values())
for value in dic.values():
print(value) print(dic.items())
for item in dic.items():
print(item)
dic = {"name": "jin", "age": 18}
for k, v in dic.items():
print(k, v) # 便利,key和value, 可只打印k或v
字典的嵌套
dic = {
'l1': ['alex', '太白'],
'id': 3,
1: {
'data': 20181225,
'place': '深圳校区',
'class': 'python3期',
'name_list': ['小潘', 'jay', '春哥', 'xx'],
}
}
# 1,给小列表['alex', '太白'] alex后面插入一个字符串,'aaa'
dic['l1'].insert(1, 'aaa')
print(dic)
dic2 = {'l1':['alex','aaa', '太白']}
# dic.update(dic2)
# print(dic)
# 2,将id对应的3变成1.
dic['id'] = 1
print(dic)
# 3,将 1 对应的字典的data变成20181224,
dic[1]['data'] = 20181224
print(dic)
dic[1]['data'] -= 1
print(dic)
# 4,将name_list对应的jay全部变成大写。
dic[1]['name_list'][1] = dic[1]['name_list'][1].upper()
print(dic)
# 4,将name_list对应的 xx 删除。
dic[1]['name_list'].pop()
dic[1]['name_list'].remove('xx')
del dic[1]['name_list'][-1]
print(dic)
格式化输出:
# 通过字典的方式
dic = {'name': '太白', 'sex': '男', 'age': 18}
msg = '我叫%(name)s,今年%(age)s,性别%(sex)s' % dic
print(msg)
formkeys()
dic = {'name': 'alex'}
dic = dict.fromkeys('abc', '春哥') #{'a': '春哥', 'b': '春哥', 'c': '春哥'}
dic = dict.fromkeys([1, 2, 3],'春哥') # {1: '春哥', 2: '春哥', 3: '春哥'}
# 坑:值如果是可变的数据类型,那么所有的值都是一个内存地址
dic = dict.fromkeys([1, 2, 3], ['alex']) #{1: ['alex'], 2: ['alex'], 3: ['alex']}
dic[1].append(666) #{1: ['alex', 666], 2: ['alex', 666], 3: ['alex', 666]}
print(dic)
day 05 字典,字典嵌套的更多相关文章
- 总结day5 ---- ,字典的学习,增删改查,以及字典的嵌套, 赋值运算
内容大纲: 一:字典的定义 二:字典的增加 >1:按照key增加, 无则增加,有则覆盖 >2:setdefault() ,无则增加,有则不变 三:字典的删除 >1:pop() ...
- Python 7 列表 for 字典,嵌套
列表: 基本格式:变量名 = [元素1,元素2,元素3] 创建:A = ['访客','admin',19] 或 A = list(['armin','admin',19]), 后者更倾向于转换为 ...
- 记录我的 python 学习历程-Day05 字典/字典的嵌套
一.字典的初识 为什么要有字典 字典与列表同属容器型数据类型,同样可以存储大量的数据,但是,列表的数据关联性不强,并且查询速度比较慢,只能按照顺序存储. 什么是字典 先说一下什么叫可变与不可变的数据类 ...
- python_字典列表嵌套的排序问题
上一篇我们聊到python 字典和列表嵌套用法,这次我们聊聊字典和列表嵌套中的排序问题,这个在python基础中不会提到,但实际经常运用,面试中也喜欢问,我们娓娓道来. 在说组合排序之前,先来看看排序 ...
- day06python 哈希 字典集合嵌套
1.hash算法 hash算法 :内存中将值进行hash算法得到一个数值存储在内存中,查找也会按照算法进行查找,使用hash算法 执行效率高相对于list的索引查找 (字典,集合):使用的是hash查 ...
- Python 字典 列表 嵌套 复杂排序大全
https://blog.csdn.net/ray_up/article/details/42084863 一: 字典排序 解析: 使用sorted 方法, 排序后的结果为一个元组. 可以字符串排序( ...
- python 元组 字符串 字典 列表嵌套练习题1
最近学习做的习题,直接复制过来 缩进就乱掉了,所以直接以图片方式上传,题目和答案一起
- python学习之第八篇——字典嵌套之字典中嵌套字典
cities = { 'shanghai':{'country':'china','population':10000,'fact':'good'}, 'lendon':{'country':'eng ...
- Python 字典的嵌套
wf = { "name":"汪峰", "age":52, "hobby":["唱歌", " ...
- python 字典格式嵌套,相同项做叠加
all_dict = {} for tg_id in ['com.qq_a','com.qq_b','com.qq_c','com.qq_c']: tmp_dict = all_dict.get(tg ...
随机推荐
- Python 百分号字符串拼接
# %s可以接收一切 %d只能接收数字 msg = 'i am %s my hobby is %s' %('lhf','alex') print msg msg2 = 'i am %s my hobb ...
- 新装kafka与zookeeper配置
zookeeper配置 dataDir=/opt/kafka_2.11-2.0.0/data/zookeeper # 尽量不要放在tmp# the port at which the clients ...
- datasnap服务器支持的参数类型
可作为参数的类型TDBXWideStringValueTDBXAnsiStringValueTDBXInt16ValueTDBXInt32ValueTDBXInt64ValueTDBXSingleVa ...
- linux 3.10 tcp的accept测试
net.ipv4.tcp_abort_on_overflow 为 0 有个兄弟跟我说accept的时候,如果故意不去accept,那么客户端connect的时候,一开始很快,后来就很慢: connec ...
- 讲一讲Servlet和JSP的关系
Test.jsp在运行时首先被解析成一个java类Test_jsp.java,该类继承于org.apache.jasper.runtime.HtppJspBase类,而Http又是继承HttpServ ...
- Android Uri获取真实路径以及文件名的方法【转】
原文地址:https://blog.csdn.net/MikoGodZd/article/details/50979653 在Android 编程中经常会用到uri转化为文件路径 下面是4.4后通过U ...
- Android DevArt4:IntentFilter学习及深入~问题描述:在不指定具体action前提下,如果有两个以上的Activity,具有完全相同的intent-filter,项目同步是否会出现异常?程序运行是否会崩溃?
概述:GitHub IntentFilter意图过滤器,三种匹配规则:action.category.data 重点:过滤规则中必须设置 '<category android:name=&quo ...
- 编程四剑客sed-2019.2.20
sed [-Options] [‘Commands’] filename; sed工具默认处理文本,文本内容输出屏幕已经修改,但是文件内容其实没有修改,需要加-i参数即对文件彻底修 ...
- tensorflow 训练cifar10报错
1.AttributeError: 'module' object has noattribute 'random_crop' 解决方案: 将distorted_image= tf.image.ran ...
- 税控服务器 TC5002UpdatePackage 安装更新
Linux版税控服务器单税号版本税控应用: TC5002UpdatePackage2008160711.zip 单税号服务器(型号:TCG-01S1) Linux版税控服务器20个 ...