博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基础数据类型{dict:'字典'}
阅读量:5104 次
发布时间:2019-06-13

本文共 2472 字,大约阅读时间需要 8 分钟。

⼀. 字典的简单介绍

   字典(dict)是python中唯⼀的⼀个映射类型.他是以{ }括起来的键值对组成. 在dict中key是唯⼀的. 在保存的时候, 根据key来计算出⼀个内存地址. 然后将key-value保存在这个地址中.这种算法被称为hash算法, 所以, 切记, 在dict中存储的key-value中的key'必须是可hash的,如果你搞不懂什么是可哈希,暂时可以这样记, 可以改变的都是不可哈希的, 那么可哈希就意味着不可变. 这个是为了能准确的计算内存地址⽽规定的.

 

已知的可哈希(不可变)的数据类型: int, str, tuple, bool

不可哈希(可变)的数据类型: list, dict, set

 

语法 :

{key1: value1, key2: value2....}
注意: key必须是不可变(可哈希)的. value没有要求.可以保存任意类型的数据

 

# 合法

dic = {123: 456, True: 999, "id": 1, "name": 'sylar', "age": 18, "stu": ['帅
哥', '美⼥'], (1, 2, 3): '麻花藤'}
print(dic[123])
print(dic[True])
print(dic['id'])
print(dic['stu'])
print(dic[(1, 2, 3)])

# 不合法

# dic = {[1, 2, 3]: '周杰伦'} # list是可变的. 不能作为key
# dic = {
{1: 2}: "哈哈哈"} # dict是可变的. 不能作为key
dic = {
{1, 2, 3}: '呵呵呵'} # set是可变的, 不能作为key

 

dict保存的数据不是按照我们添加进去的顺序保存的. 是按照hash表的顺序保存的. ⽽hash表不是连续的. 所以不能进⾏切片⼯作. 它只能通过key来获取dict中的数据

 

⼆. 字典的增删改查和其他相关操作

1. 增加

dic = {}

dic['name'] = '周润发' # 如果dict中没有出现这个key, 就会新增⼀个key-value的组合进dict

dic['age'] = 18

print(dic)

# 如果dict中没有出现过这个key-value. 可以通过setdefault设置默认值

dic.setdefault('李嘉诚') # 也可以往⾥⾯设置值.

dic.setdefault("李嘉诚", "房地产") # 如果dict中已经存在了. 那么setdefault将不会起作⽤

print(dic)

 

2. 删除

ret = dic.pop("jay")

print(ret)
del dic["jay"]
print(dic)
# 随机删除.
ret = dic.popitem()
# 清空字典中的所有内容
dic.clear()

 

 

3. 修改

dic = {"id": 123, "name": 'sylar', "age": 18}

dic1 = {"id": 456, "name": "麻花藤", "ok": "wtf"}
dic.update(dic1) # 把dic1中的内容更新到dic中. 如果key重名. 则修改替换. 如果不存在key, 则新增.
print(dic)
print(dic1)

 

4. 查询

查询⼀般⽤key来查找具体的数据. 

 

print(dic['name'])

# print(dic['sylar']) # 报错
print(dic.get("ok"))
print(dic.get("sylar")) # None
print(dic.get("sylar", "NB")) # NB

 

5. 其他相关操作

 

dic = {"id": 123, "name": 'sylar', "age": 18, "ok": "科⽐"}

print(dic.keys()) # dict_keys(['id', 'name', 'age', 'ok']) 不⽤管它是什么.当
成list来⽤就⾏
for key in dic.keys():
print(key)

print(dic.values()) # dict_values([123, 'sylar', 18, '科⽐']) ⼀样. 也当

list来⽤
for value in dic.values():
print(value)
print(dic.items()) # dict_items([('id', 123), ('name', 'sylar'), ('age',18), ('ok', '科⽐')]) 这个东⻄也是list. 只不过list中装的是tuplefor key, value in dic.items(): # ?? 这个是解构

print(key, value)

# 解构
a, b = 1, 2
print(a, b)
(c, d) = 3, 4
print(c, d)

e, f = [1, 2, 3] # 解构的时候注意数量必须匹配

print(e, f)

 

三. 字典的嵌套

# 字典的嵌套

dic1 = {
  "name": "汪峰",
  "age": 18,
  "wife": {
    "name": '章⼦怡',
    "age": 28
  },
  "children": ['第⼀个⽑孩⼦', '第⼆个⽑孩⼦'],
  "desc": '峰哥不会告我吧. 没关系. 我想上头条的'
  }
print(dic1.get("wife").get("name"))

print(dic1.get("children"))

print(dic1.get("children")[1])

 

转载于:https://www.cnblogs.com/Ajie-boby/p/10217021.html

你可能感兴趣的文章
mac下的mysql报错:ERROR 1045(28000)和ERROR 2002 (HY000)的解决办法
查看>>
快速幂
查看>>
AIO 开始不定时的抛异常: java.io.IOException: 指定的网络名不再可用
查看>>
MyBaits动态sql语句
查看>>
HDU4405(期望DP)
查看>>
拉格朗日乘子法 那些年学过的高数
查看>>
vs code 的便捷使用
查看>>
Spring MVC @ResponseBody返回中文字符串乱码问题
查看>>
用户空间与内核空间,进程上下文与中断上下文[总结]
查看>>
JS 中的跨域请求
查看>>
JAVA开发环境搭建
查看>>
mysql基础语句
查看>>
Oracle中的rownum不能使用大于>的问题
查看>>
[Data Structure & Algorithm] 有向无环图的拓扑排序及关键路径
查看>>
cassandra vs mongo (1)存储引擎
查看>>
Visual Studio基于CMake配置opencv1.0.0、opencv2.2
查看>>
遍历Map对象
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
#Leetcode# 209. Minimum Size Subarray Sum
查看>>
SDN第四次作业
查看>>