有关于dict(字典)的特性与操作方法

1.字典的特性

语法:

dic = {key1 : value1,key2 : value2,key3 : value3............}

注:字典中key的值不可改变,value的值可以改变;由于字典保存数据使用的是Hash存储方式 故字典无法使用切片方式.

2.字典的操作方法

1.增加

dic = {}

1) dic ["name"] = "伍四六"

#如果字典中没有该key值,则在字典最后加入字典元素,如果存在该key值则会覆盖该key值 所对应的value值

2) dic.setdefault(key , default = None)

#使用此方法时,如果字典中没有过这个key则在字典末尾增加这个字典元素,若key已经存 在则此语句无效

##该方法默认的value值为None,可自行设定value值

2.删除

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

1) dic.pop(key) #删除指定key值与其指定的value值,并返回value值

注:字典中的pop()与列表中的pop()不同,字典中pop()如果不指定key值会报错,而列表中 pop()不指定索引值是默认删除列表最后一个元素

2) del dic[key] #删除指定key值的字典元素

3) dic.popitem() #随机删除一个字典元素,并返回该字典元素

4) dic.clear() #清除字典中所有的元素

3.修改

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

1) 可直接对字典元素的value进行修改

例: dic["姑姑"] = 154

2) dic.update(另一个字典)

#把另一个字典中的内容更新到dic字典中,若key值重复则覆盖其value;若不重复,则新增 字典元素

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

dic1 = {"id": 456, "name": "麻花藤", "ok": "wtf"}

dic.update(dic1)

4.查询

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

1) 直接用key去查询

例: print(dic['name']) #得到123

2) dic.get(key) #获取key值的value,如果key不存在,则返回None

5.其他相关操作

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

1) dic.keys()

#输出一个可通过list()转化为列表的代码段,代码段中记录了字典中所有的key值;可通过 for循环直接输出

例: for key in dic.keys()

print(key)

2) dic.values()

#输出一个可通过list()转化为列表的代码段,代码段中记录了字典中所有的value值;可通 过for循环直接输出

例: for value in dic.values()

print(value)

3) dic.item()

#输出一个可通过list()转化为列表的代码段,代码段中记录了字典中所有的字典元素,所有 的字典元素装在tuple(元组)中构成列表的每一个元素;可通过for循环直接输出

例:print(dic.items()) # dict_items([('id', 123), ('name', 'sylar'), ('age',18),("姑姑",None)] 这个东西也是list. 只不过list中装的是tuple

for key, value in dic.items(): # 这个是解构

print(key, value)

6.解构

1) a,b = 1,2 或 (a,b) = (1,2)这类就属于解构

注:解构时要注意数量必须匹配,否则报错

2) 参数解构

#给函数提供实参的时候,可以在集合类型前使用 * 或者 ** ,把集合类型的结构解开,并提 出所有元素为函数提供实参

##非字典类型使用 * 来解构成位置参数

##字典类型使用 ** 来解构成关键字参数

@@@这里注意提取出来的元素数目要与参数的数目一致,不然会报错

例:

def add(x, y): ​ add(4, 5) #正常调用 ​ add((4,5)) #错误调用被当做一个参数 ​ add( * (4,5)) #参数解构 ​ add( * range(1,3)) #与上类似 ​ add( ** {'a' : 5, 'b' : 6}) #解构value ​ add( * {'a' : 5, 'b' : 6}) #解构key

7.字典的嵌套

dic1 = { "name": "汪峰", "age": 18, "wife": { "name": '章子怡', "age": 28 }, "children": ['第一个毛孩子', '第二个毛孩子'], "desc": '峰哥不会告我吧. 没关系. 我想上头条的' }

print(dic1["wife"] ["name"])

print(dic1.get("wife").get("name"))

print(dic1.get("children"))

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

有关于dict(字典)的特性与操作方法的更多相关文章

  1. Python的dict字典结构操作方法学习笔记

    Python的dict字典结构操作方法学习笔记 这篇文章主要介绍了Python的dict字典结构操作方法学习笔记本,字典的操作是Python入门学习中的基础知识,需要的朋友可以参考下 一.字典的基本方 ...

  2. 1.12 dict 字典表

    dict 字典表属于映射分类 dict的声明 >>> #dict类型 是 {}中包含若干个键值对 >>> d = dict() >>> d = { ...

  3. python数据类型之dict(字典)

    dict字典 关注公众号"轻松学编程"了解更多. 1.概述 dict也是一种存储方式,类似于list和tuple,但是,字典采用键-值(key-value)的形式存储. 优点:具有 ...

  4. 数据类型:list列表[]、元祖tuple()、dict字典{}

    List 列表[] 可变的 lst = [1,2,3,4] #改 lst[(元素下标)] = '需要修改的' #通过下表修改 lst[下标:下标] = '需要修改的' #通过范围修改 #加 lst.a ...

  5. Python数据类型的内置函数之tuple(元组),dict(字典),set(集合)

    Python数据类型内置函数 - str(字符串) - list(列表) - tuple(元组) - dict(字典) - set(收集) tuple(元组)的操作 - (count)统计元组中元素出 ...

  6. 列表 list 容器类型数据(str字符串, list列表, tuple元组, set集合, dict字典)--->元组 tuple-->字符串 str

    # ### 列表 list 容器类型数据(str字符串, list列表, tuple元组, set集合, dict字典) # (1)定义一个列表 listvar = [] print(listvar, ...

  7. python的dict()字典数据类型的方法详解以及案例使用

    一.之前的回顾 # int  数字 # str 字符串 # list 列表 # tuple 元组 # dict 字典 字典中最重要的方法 keys() values() items() get upd ...

  8. Python 全栈开发:dict(字典)常用方法操作、dict嵌套

    数据类型的划分:可变数据类型和不可变数据类型. 不可变数据类型(可哈希):元祖.bool.int.str 可变数据类型(不可哈希):list.dict,set(集合) dict(字典): dict(字 ...

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

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

随机推荐

  1. day01-编程与计算机组成原理

    什么是编程 编程语言:是人与计算机沟通交流的介质,通过标准化的规则传递信息 编程:就是为了使计算机能够理解人的意图,通过编程语言写出一个个文件,这堆文件完成相应的目的 编程的目的:用计算机取代人完成工 ...

  2. lsof command not found 解决

    有些centos 没有 lsof命令,需要安装 yum install lsof -y 使用: lsof -i:端口号

  3. mysql cpu 100% 满 优化方案 解决MySQL CPU占用100%的经验总结

    下面是一些经验 供参考 解决MySQL CPU占用100%的经验总结 - karl_han的专栏 - CSDN博客 https://blog.csdn.net/karl_han/article/det ...

  4. PAT_A1003#Emergency

    Source: PAT A1003 Emergency (25 分) Description: As an emergency rescue team leader of a city, you ar ...

  5. adjtimex和时钟的几个概念tick,freq,ppm,jiffies

    adjtimex使用 今天遇到一个ntp的同步问题.服务器上配置好了ntpd,在启动前也手动进行过同步,但是过段时间ntpq查询发现服务器即便能选出同步服务器,但是系统的时间偏差越来越大. 服务器上实 ...

  6. [如何在mac下使用gulp] 2. gulp模块的常用方法

    常用的gulp模块方法有: gulp.src() gulp.src('client/one.js'); //指定明确的要处理文件 gulp.src('client/*.js'); //处理client ...

  7. enote笔记语言(5)——其他

    章节:其他   ((主:单词))                               用来醒目地强调这个句子中哪个词语作主语 sentence:                         ...

  8. redis环境部署

    运维开发技术交流群欢迎大家加入一起学习(QQ:722381733) 一.Redis服务介绍: redis简单来讲就是一个数据库,一个用来存储缓存的数据库容器,主要是让项目数据能写进缓存,为用户提搞更舒 ...

  9. tensorflow的数据输入

    tensorflow有两种数据输入方法,比较简单的一种是使用feed_dict,这种方法在画graph的时候使用placeholder来站位,在真正run的时候通过feed字典把真实的输入传进去.比较 ...

  10. SqlServer转换为Mysql(mss2sql)

    SqlServer转换为Mysql(mss2sql)工具 http://pan.baidu.com/s/1c2d8R8O 参考链接: http://www.cnblogs.com/angestudy/ ...