补充知识点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(字典)的更多相关文章

  1. [Python] dict字典的浅复制与深复制

    Python中针对dict字典有两种复制: (1)浅复制:利用 copy() 或者 dict() :复制后对原dict的内部子对象(方括号[]内元素)进行操作时,由浅复制得到的dict会受该操作影响 ...

  2. python dict 字典

    字典是通过hash表的原理实现的,每个元素都是一个键值对,通过元素的键计算出一个唯一的哈希值,这个hash值决定了元素的地址,因此为了保证元素地址不一样,必须保证每个元素的键和对应的hash值是完全不 ...

  3. Python dict字典方法完全攻略(全)

    我们知道,Python 字典的数据类型为 dict,我们可使用 dir(dict) 来查看该类型包含哪些方法,例如: >>> dir(dict)['clear', 'copy', ' ...

  4. Python - dict 字典常见方法

    字典详解 https://www.cnblogs.com/poloyy/p/15083781.html get(key) 作用 指定键,获取对应值 两种传参 dict.get(key):键存在则返回对 ...

  5. Python - dict 字典的多种遍历方式

    前置知识 for 循环详解:https://www.cnblogs.com/poloyy/p/15087053.html 使用 for key in dict 遍历字典 可以使用 for key in ...

  6. Python - DICT 字典排序 - OrderedDict

    官方地址: https://docs.python.org/2/library/collections.html#collections.OrderedDict >>> # regu ...

  7. python dict字典和set集合用法

    创建字典:键  值  key  value c = {'张三':59, '李四':60, '王五':100} #查 print(c['张三'])  #打印张三的成绩 #改 c['张三'] = 60 # ...

  8. python dict字典添加元素

    已存在的字典进行赋值操作 可为该字典添加新元素例子:a = {‘age’: 23, ‘name’: ‘lala}a[school] = ‘nanhaizhongxue’print a>>& ...

  9. python dict字典常用操作

    字典的特性:key唯一无序 '''特性:key唯一:无序''' info = { 'stu1101': "安徽", 'stu1102': "北京", 'stu1 ...

  10. Python dict 字典 keys和values对换

    原字典: d1 = { 'en':'英语', 'cn':'中文', 'fr':'法语', 'jp':'日语' } 经过相互对换: d1_inverse = {values:keys for keys, ...

随机推荐

  1. IDEA新建一个多maven模块工程(有图)

    对于一些大型的项目来说,将项目的各个模块理清并进行管理,便于后续项目的维护,使用maven管理是很方便的,它可以很好的构建模块来设计项目的整体结构,对一些小型的项目不建议使用 1.新建父maven模块 ...

  2. 【Unity与Android】02-在Unity导出的Android工程中接入Google Admob广告

    我在上一篇文章 [Unity与Android]01-Unity与Android交互通信的简易实现) 中介绍了Unity与Android通讯的基本方法. 这一篇开始进入应用阶段,这次要介绍的是如何在An ...

  3. 分库分表(2) --- ShardingSphere(理论)

    ShardingSphere---理论 ShardingSphere在中小企业需要分库分表的时候用的会比较多,因为它维护成本低,不需要额外增派人手;而且目前社区也还一直在开发和维护,还算是比较活跃. ...

  4. 【集群监控】JMX exporter+Prometheus+Grafana监控Hadoop集群

    下载jmx_exporter的jar包 https://repo1.maven.org/maven2/io/prometheus/jmx/jmx_prometheus_javaagent/0.3.1/ ...

  5. python正则表达式贪婪算法与非贪婪算法与正则表达式子模式的简单应用

    先引入一下百度百科对于正则表达式的概念: 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种 ...

  6. ElasticSearch实战系列三: ElasticSearch的JAVA API使用教程

    前言 在上一篇中介绍了ElasticSearch实战系列二: ElasticSearch的DSL语句使用教程---图文详解,本篇文章就来讲解下 ElasticSearch 6.x官方Java API的 ...

  7. 【SQL】sql查询同一字段相同属性列的值合计

    select  type,sum(value) as valueSum from t group by type

  8. 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 ...

  9. 虚拟机上安装centos8.0

    一.准备宿主机 为了培训Hadoop生态的部署和调优技术,需要准备3台虚拟机部署Hadoop集群环境,能够保证HA,即主要服务没有单点故障,可执行基本功能,完成小内存模式的参数调整. 1.1.准备安装 ...

  10. Uber Go 语言编程规范

    目录 Uber Go 语言编程规范 1. 介绍 2. 编程指南 3. 性能相关 4. 编程风格 5. 编程模式(Patterns) 6. 总结 Uber Go 语言编程规范 相信很多人前两天都看到 U ...