python dict(字典)
补充知识点1:
数据类型的划分:可变数据类型、不可变数据类型
可变数据类型: 元组,bool,int,str --可哈希
不可变数据类型: list,dict,set --不可哈希
dict key: 必须是不可变数据类型,可哈希
dict value:可以是任意数据类型
dict优缺点:①利用效率高的二分查找法查询数据 ②可以储存大量的关系型数据 ③Python3.5版本(包括此版本)之前,字典是无序的。在Python3.6版本之后,字典按照初建字典时的顺序排列。缺点:内存消耗巨大。
字典的常用操作方法
1.增
①通过键值对添加(无key添加,有key则value覆盖)
②setdefault(无key添加,有key跳过;有返回值)
dic1 = {'name': '太白', 'age': 18}
# 通过键值对直接增加,有key则覆盖值
dic1['weight'] = 65
dic1['name'] = 'jin-xin'
print(dic1) # {'name': 'jin-xin', 'age': 18, 'weight': 65} dic2 = {'name': '太白', 'age': 18}
# setdefault 无key添加,有key跳过;有返回值
dic2.setdefault('height', 180)
dic2.setdefault('name', 'alex')
print(dic2) # {'name': '太白', 'age': 18, 'height': 180}
print(dic2.setdefault('name')) # 太白
2.删
①pop(通过key删除键值对;有返回值)
②popitem(删除最后一个(3.6版本之后);有返回值)
③lcear(清空)
④del(删除)
dic1 = {'name': '太白', 'age': 18, 'height': 180}
# pop 通过key删除键值对;有返回值
print(dic1.pop('name'), dic1) # 太白 {'age': 18, 'height': 180} # popitem 删除最后一个(3.6版本之后);有返回值
print(dic1.popitem(), dic1) # ('height', 180) {'age': 18} # clear 清空
dic1.clear()
print(dic1) # {} dic2 = {'name': '太白', 'age': 18, 'height': 180}
# del 删除
del dic2['name']
print(dic2) # {'age': 18, 'height': 180}
del dic2
print(dic2) # 报错
3.改
①通过key直接更改
②update
dic = {'name': '太白', 'age': 18}
# 通过key直接更改
dic['name'] = 'alex'
print(dic) # {'name': 'alex', 'age': 18} # update
dic.update(age=22, height=180)
print(dic) # {'name': 'alex', 'age': 22, 'height': 180}
dic.update([(1,'a'), (2, 'b')])
print(dic) # {'name': 'alex', 'age': 22, 'height': 180, 1: 'a', 2: 'b'} dic1 = {1: 'a', 2: 'b', 3: 'c'}
dic2 = {2: 'b', 3: 't', 4: 'd'}
dic2.update(dic1) # 字典1添加/替换到字典2中,有key覆盖value,无key添加键值对
print(dic1) # {1: 'a', 2: 'b', 3: 'c'}
print(dic2) # {2: 'b', 3: 'c', 4: 'd', 1: 'a'}
4.查
①通过key查询
②get
③keys values itmes
dic = {'name': '太白', 'age': 18}
# 通过key查询
print(dic['name']) # 太白 # get 有返回值(可设置)
print(dic.get('name')) # 太白
print(dic.get('height')) # None # keys values items
print(dic.keys()) # dict_keys(['name', 'age'])
print(dic.values()) # dict_values(['太白', 18])
print(dic.items()) # dict_items([('name', '太白'), ('age', 18)])
补充知识点2:分别赋值,也叫拆包
a = 1
b = 2
print(a, b) # 1 2
a, b = b, a
print(a, b) # 2 1 a, b = (123, 321)
print(a, b) # 123 321
a, b = ['age', 'high']
print(a, b) # age high
a, b = {'name': 'zzl', 'age': 22}
print(a, b) # name age
相关练习题:
如有下列物品:1:手机, 2:电脑, 3:鼠标垫, 4:游艇
# 创建一个用户查询程序: 1.用户输入相应序号,输出对应物品名称;如果没有则提示输入有误
# 2.用户输入列表或list展示所有:序号 物品
# 如:1 手机
# 2 电脑
# 3 鼠标垫
# ...
# 3.用户输入Q或q退出程序
dic = {1: '手机', 2: '电脑', 3: '鼠标垫', 4: '游艇'} while 1:
uaers_in = input('请输入序号查询商品(查看商品列表请输入列表/list;输入Q/q退出):')
if uaers_in == 'list' or uaers_in == '列表':
for k, v in dic.items():
print(k, v)
elif uaers_in == 'Q' or uaers_in == 'q':
print('---程序已退出!---')
break
else:
print(dic.get(int(uaers_in), '输入有误,请重新输入'))
flag = True
while flag:
li = ["手机", "电脑", "鼠标垫", "游艇"]
for i in li:
print('{}\t\t{}'.format(li.index(i)+1,i))
num_of_chioce = input('请输入选择的商品序号/输入Q或者q退出程序:')
if num_of_chioce.isdigit():
num_of_chioce = int(num_of_chioce)
if num_of_chioce > 0 and num_of_chioce <= len(li):
print(li[num_of_chioce-1])
else:print('请输入有效数字')
elif num_of_chioce.upper() == 'Q':
break
else:
print('请输入数字')
python dict(字典)的更多相关文章
- [Python] dict字典的浅复制与深复制
Python中针对dict字典有两种复制: (1)浅复制:利用 copy() 或者 dict() :复制后对原dict的内部子对象(方括号[]内元素)进行操作时,由浅复制得到的dict会受该操作影响 ...
- python dict 字典
字典是通过hash表的原理实现的,每个元素都是一个键值对,通过元素的键计算出一个唯一的哈希值,这个hash值决定了元素的地址,因此为了保证元素地址不一样,必须保证每个元素的键和对应的hash值是完全不 ...
- Python dict字典方法完全攻略(全)
我们知道,Python 字典的数据类型为 dict,我们可使用 dir(dict) 来查看该类型包含哪些方法,例如: >>> dir(dict)['clear', 'copy', ' ...
- Python - dict 字典常见方法
字典详解 https://www.cnblogs.com/poloyy/p/15083781.html get(key) 作用 指定键,获取对应值 两种传参 dict.get(key):键存在则返回对 ...
- Python - dict 字典的多种遍历方式
前置知识 for 循环详解:https://www.cnblogs.com/poloyy/p/15087053.html 使用 for key in dict 遍历字典 可以使用 for key in ...
- Python - DICT 字典排序 - OrderedDict
官方地址: https://docs.python.org/2/library/collections.html#collections.OrderedDict >>> # regu ...
- python dict字典和set集合用法
创建字典:键 值 key value c = {'张三':59, '李四':60, '王五':100} #查 print(c['张三']) #打印张三的成绩 #改 c['张三'] = 60 # ...
- python dict字典添加元素
已存在的字典进行赋值操作 可为该字典添加新元素例子:a = {‘age’: 23, ‘name’: ‘lala}a[school] = ‘nanhaizhongxue’print a>>& ...
- python dict字典常用操作
字典的特性:key唯一无序 '''特性:key唯一:无序''' info = { 'stu1101': "安徽", 'stu1102': "北京", 'stu1 ...
- Python dict 字典 keys和values对换
原字典: d1 = { 'en':'英语', 'cn':'中文', 'fr':'法语', 'jp':'日语' } 经过相互对换: d1_inverse = {values:keys for keys, ...
随机推荐
- IDEA新建一个多maven模块工程(有图)
对于一些大型的项目来说,将项目的各个模块理清并进行管理,便于后续项目的维护,使用maven管理是很方便的,它可以很好的构建模块来设计项目的整体结构,对一些小型的项目不建议使用 1.新建父maven模块 ...
- 【Unity与Android】02-在Unity导出的Android工程中接入Google Admob广告
我在上一篇文章 [Unity与Android]01-Unity与Android交互通信的简易实现) 中介绍了Unity与Android通讯的基本方法. 这一篇开始进入应用阶段,这次要介绍的是如何在An ...
- 分库分表(2) --- ShardingSphere(理论)
ShardingSphere---理论 ShardingSphere在中小企业需要分库分表的时候用的会比较多,因为它维护成本低,不需要额外增派人手;而且目前社区也还一直在开发和维护,还算是比较活跃. ...
- 【集群监控】JMX exporter+Prometheus+Grafana监控Hadoop集群
下载jmx_exporter的jar包 https://repo1.maven.org/maven2/io/prometheus/jmx/jmx_prometheus_javaagent/0.3.1/ ...
- python正则表达式贪婪算法与非贪婪算法与正则表达式子模式的简单应用
先引入一下百度百科对于正则表达式的概念: 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种 ...
- ElasticSearch实战系列三: ElasticSearch的JAVA API使用教程
前言 在上一篇中介绍了ElasticSearch实战系列二: ElasticSearch的DSL语句使用教程---图文详解,本篇文章就来讲解下 ElasticSearch 6.x官方Java API的 ...
- 【SQL】sql查询同一字段相同属性列的值合计
select type,sum(value) as valueSum from t group by type
- github代码仓库提示:“We found a potential security vulnerability in one of your dependencies”
问题描述: Github上传代码后出现这样的错误: We found a potential security vulnerability in one of your dependencies. A ...
- 虚拟机上安装centos8.0
一.准备宿主机 为了培训Hadoop生态的部署和调优技术,需要准备3台虚拟机部署Hadoop集群环境,能够保证HA,即主要服务没有单点故障,可执行基本功能,完成小内存模式的参数调整. 1.1.准备安装 ...
- Uber Go 语言编程规范
目录 Uber Go 语言编程规范 1. 介绍 2. 编程指南 3. 性能相关 4. 编程风格 5. 编程模式(Patterns) 6. 总结 Uber Go 语言编程规范 相信很多人前两天都看到 U ...