一、字典

一、关键字:dict

1.字典是唯一的键值对数据,其表现形式:   dic  =  {键:值},​字典里的键必须保证是唯一的

2.键必须是不可变的数据类型:

    ​a、故列表是不能当键的

    b、所以元组(内部没有可变的数据类型)是可以当键的​.

​    c、而字典也不可以当字典的键的,因为字典是可变的.

3.值是没有要求的.​

​ dic = {'Key':1,1:'True',False:'asdf',{1,2,3}:[1,2,3,4]}​

注:​len()是一个python的内置函数,查询数据类型的长度的。什么数据类型都可以用​.

4.不可变数据类型:(可哈希)

     数字 字符串 元组 布尔值

5.可变数据类型:(不可哈希)

    列表 字典​​

注:字典是无序的,但是py36是有序打印的,3.5及以下版本是无序打印​.

二、增加:

1.dic[' '] = ' '                        #很暴力,直接添加就好了.#如果这个键不在字典中就是添加,在字典中就是修改

#增加:
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
dic['k4'] = 'v4'
dic['k3'] = 'v3'
dic.setdefault('k5')
print(dic)

2.dic.setdefault(' 键',' 值') #如果在列表中键存在就不进行添加​​,不存在进行添加.如果不写值就默认值为None

dic = {}
dic['歌手'] = '汪峰'
print(dic)
dic.setdefault('王菲','歌手')
print(dic)
dic.

三、删除:

注:字典中没有remove()方法 注意!!!!!!!!!!!!!!!!!

.pop(键)​                 #删除这个键所对应的键值对,有返回值 #返回这个键所对应的值

.popitem()              #随机删除,在3.6版本以上删除最后一个,3.5及以下版本随机删除有返回值 #返回的是这个键所对应的键值对,一元组的形式输出.第一个是键,第二个是值

del dic                    #删除整个字典

del dic['键']             #通过键删除一个键值对​​​​

.clear()                   #清空​

注意(此处神坑):

#字典在for循环中是不能进行删除的但是可以用方法规避在原字典使用for循环

dic = {'a':1,'b':2}
dic1 = {} #通过建立一个新的字典
for i in dic:
  dic1[i] = dic[i] #规避for的循环机制
for i in dic1:
  dic.pop(i)
  print(dic)

四、改:​

dic['键']                  #如果这个键在字典中就是修改,不在就是添加

.update('键':'值')    #更新  如果这个键在字典中就是修改,不在就是添加

五、查:

.get('键',返回值)​​   #查询的是键所对应的值,如果没有该建,则默认返回None,返回值可以自己定义.​

print(dic['键'])       #也是查询键所对应的值,但是没有该键,则报错.​

六、字典的其他操作:

dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}​

for i in dic:

print(i)    #遍历的是字典的键

if i in dic:

print(dic[i])​​   #没有返回值

print( dic.get(i))   #有返回值

七、字典独有的方法:

.keys()         #对应字典的键   以元组的方式将键放在一个高仿列表里

.value()       #对应字典的值  一元组方式将值放在一个高仿列表里

.items()        #对应字典的键值对 以元组形式将键值对放在一个高仿列表里​​​​​​​之所以叫高仿列表是因为无索引所以叫高仿

for k,v in dic.items():        #通过解构赋值

     print('这是键',k)

     print('这是值',v)​

八、解构赋值:​

a,b = 1,2 即将ab分别赋值1和2 ,位置对应即可。

1.数字:

​a,b = 1,2

print(a,b)

结果:

1  2

2.元组:

a,b = ('你好','汪峰')

print(a,b)

结果:

你好 汪峰

3.列表:

a,b = ['你好','汪峰']

print(a,b)

结果:

你好 汪峰

4.字典:

a,b = {'汪峰':'男的','章子怡':'女的'}

print(a,b)

结果:

汪峰 章子怡

例:​ 用一行代码将ab的值调换 a=10 b=20

利用解构赋值即可:

a,b = b, a

print(a,b)​​

​这个解构赋值适用于数字,字符串,列表,元组,字典等数据类型​

八、字典的嵌套:

dic1 = {
'name':['alex',2,3,5],
'job':'teacher',
'oldboy':{'alex':['python1','python2',100]}
}
dic1['name'].append('wusir')
print(dic1)
s = dic1['name'][0].title()
print(s)
dic1['oldboy']['alex'].remove('python2')
print(dic1)
字典是无序的可变可迭代的数据类型

python七类之字典详解的更多相关文章

  1. Python包模块化调用方式详解

    Python包模块化调用方式详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一般来说,编程语言中,库.包.模块是同一种概念,是代码组织方式. Python中只有一种模块对象类型 ...

  2. Python中的高级数据结构详解

    这篇文章主要介绍了Python中的高级数据结构详解,本文讲解了Collection.Array.Heapq.Bisect.Weakref.Copy以及Pprint这些数据结构的用法,需要的朋友可以参考 ...

  3. [转]使用python来操作redis用法详解

    转自:使用python来操作redis用法详解 class CommRedisBase(): def __init__(self): REDIS_CONF = {} connection_pool = ...

  4. Python API 操作Hadoop hdfs详解

    1:安装 由于是windows环境(linux其实也一样),只要有pip或者setup_install安装起来都是很方便的 >pip install hdfs 2:Client——创建集群连接 ...

  5. 对python3中pathlib库的Path类的使用详解

    原文连接   https://www.jb51.net/article/148789.htm 1.调用库 ? 1 from pathlib import 2.创建Path对象 ? 1 2 3 4 5 ...

  6. Python中格式化format()方法详解

    Python中格式化format()方法详解 Python中格式化输出字符串使用format()函数, 字符串即类, 可以使用方法; Python是完全面向对象的语言, 任何东西都是对象; 字符串的参 ...

  7. python设计模式之装饰器详解(三)

    python的装饰器使用是python语言一个非常重要的部分,装饰器是程序设计模式中装饰模式的具体化,python提供了特殊的语法糖可以非常方便的实现装饰模式. 系列文章 python设计模式之单例模 ...

  8. Python调用windows下DLL详解

    Python调用windows下DLL详解 - ctypes库的使用 2014年09月05日 16:05:44 阅读数:6942 在python中某些时候需要C做效率上的补充,在实际应用中,需要做部分 ...

  9. Python操作redis字符串(String)详解 (三)

    # -*- coding: utf-8 -*- import redis #这个redis不能用,请根据自己的需要修改 r =redis.Redis(host=") 1.SET 命令用于设置 ...

随机推荐

  1. Java—集合框架Set

    Set接口及其实现类——HashSet Set是元素无序并且不可以重复的集合,被称作集. HashSet—哈希集,是Set的一个重要实现类. Set的使用   HashSet没有像List一样的set ...

  2. 面向对象设计中private,public,protected的访问控制原则及静态代码块的初始化顺序

    第一:private, public, protected访问标号的访问范围. private:只能由          1.该类中的函数          2.其友元函数访问 不能被任何其他访问,该 ...

  3. django模型详解(四)

    1 概述 (1)概述 : Django对各种数据库提供了很好的支持,Django为这些数据库提供了统一的调用API,根据不同的业务需求选择不同的数据库 (2)定义模型 模型,属性,表,字段间的关系 一 ...

  4. visual studio 调试 不进断点 断点失效 提示当前不会命中该断点等问题解决

    1.首先看一下  当前调试模式是否为debug 2. 点击[调试]>[选项和设置] 将[要求源文件与原始文件完全匹配]勾选掉 3.点击调试的最后一个选项 点击[web] 将调试器内部勾选上需要测 ...

  5. t d x 示例z

    using System; using System.Collections.Generic; using System.Linq; using System.Runtime.InteropServi ...

  6. monkey使用

    一.Monkey测试原理:Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中.它向系统发送伪随机的用户事件流(如按键输入.触摸屏输入.手势输入等),实现对正在开发的应用程序 ...

  7. helm回滚应用

    helm状态显示为部署,但容器可能不是running 以下是helm的解释 大概意思是helm只要在k8s上执行完成就当做成功,容器部署到创建状态已经不在Helm的角色设定里了 执行回滚前先模拟下过程 ...

  8. ORACLE_TRIGGER

    PL/SQL TRIGGER Statement PL/SQL TRIGGER  Statement The trigger statemet is a especially stored proce ...

  9. python入门23 pymssql模块(python连接sql server增删改数据 )

    增删改数据必须connect.commit()才会生效 回滚函数 connect.rollback() 连接数据库 ''' dinghanhua sql server增删改 ''' import py ...

  10. Power Designer逆向工程连接数据库创建pdm-oracle

    1.进入菜单文件-Reverse Engineer-Database... 2.打开窗口,选择数据库版本,点击[确定] 3.打开窗口,选择Usering a data source: 4.如果已经有d ...