一、字典的介绍

字典:字典是Python的基础数据类型之一:字典可以存储大量数据,关系型数据。

同样是Python中唯一的映射类数据类型。
         数据类型的分类:
        可变的数据类型:list,dic
        不可变的数据类型:str ,int ,bool,tuple
特点:
       键值对的形式存在,键:值
      字典的键必须是不可变的数据类型。(工作中:都是由 数字或者str组成)
     字典的值可以是任意数据类型

优点 :
       字典可以存储大量的数据,关系型数据。
       查询速度快

注意:
        python3.5之前包括3.5版本,字典是无序的。
       python3.6开始是有序的。

二、增

方法一:

dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
dic1['sex'] = '男'
dic1['name'] = 'alex' # 通过键去增或者改
dic1['job'] = 'it'
print(dic1)

方法二:

dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
dic1.setdefault('job','it')
dic1.setdefault('name', 'alex')
print(dic1)
# setdefault 有次key则不做任何操作但是返回对应值,无此key则添加
结果为:
{'name': '太白', 'age': 25, 'sex': 'M', 'job': 'it'}

三、删

方法一:

dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
# pop 通过键去删除键值对,也返回值。
print(dic1.pop('name'))
print(dic1)
结果为:
太白

{'age': 25, 'sex': 'M'}

print(dic1.pop('name1', None)) # None 可以使任意内容

  print(dic1.pop('name1', '没有此键。。。'))

结果为:

None
没有此键。。。

方法二:

#clear   清空
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
dic1.clear()
print(dic1)
结果为:
{}

方法三:

# popitem  # 删最后一个3.6     随机删除3.5
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
print(dic1.popitem())
print(dic1)
结果为:

('sex', 'M')
{'name': '太白', 'age': 25}

方法四:

# del
# (1) 按照键去删除
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
del dic1['name']
print(dic1)
结果为:
{'age': 25, 'sex': 'M'} # (2) 内存级别的删除字典
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'
del dic1
print(dic1)
结果为:
直接报错
# (1)两个字典 update
dic = {'name':'jim','age':18,'sex':'M'}
dic2 = {'name':'alex','weight':75}
dic.update(dic2) # 将dic2中的所有键值对覆盖并添加到dic中,dic2不变。
print(dic)
print(dic2)
结果为:
{'name': 'alex', 'age': 18, 'sex': 'M', 'weight': 75}
{'name': 'alex', 'weight': 75} # (2) update 可以直接将字符串添加到列表
dic = {'name':'jim','age':18,'sex':'M'}
dic.update(a='', b='', name='taibai')
print(dic)
结果为:
{'name': 'taibai', 'age': 18, 'sex': 'M', 'a': '', 'b': ''}

四、改

方法一:

dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
dic1['sex'] = '男'
dic1['name'] = 'alex' # 通过键去增或者改
dic1['job'] = 'it'
print(dic1)

方法二:

# (1)两个字典 update
dic = {'name':'jim','age':18,'sex':'M'}
dic2 = {'name':'alex','weight':75}
dic.update(dic2) # 将dic2中的所有键值对覆盖并添加到dic中,dic2不变。
print(dic)
print(dic2)
结果为:
{'name': 'alex', 'age': 18, 'sex': 'M', 'weight': 75}
{'name': 'alex', 'weight': 75} # (2) update 可以直接将字符串添加到列表
dic = {'name':'jim','age':18,'sex':'M'}
dic.update(a='', b='', name='taibai')
print(dic)
结果为:
{'name': 'taibai', 'age': 18, 'sex': 'M', 'a': '', 'b': ''}

五、查

方法一:

# 根据键去查
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
print(dic1['name'])
print(dic1['name1']) # 没有该键即直接报错

方法二:

# (2) get方法
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
print(dic1.get('name'))
print(dic1.get('name1'))
print(dic1.get('name1','没此键。。。')) # 可以为任意值
结果为:
太白
None
没此键。。。

方法三:

# (3)key方法
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
print(dic1.keys(), type(dic1.keys())) # 类似于列表的容器中
l1 = list(dic1.keys()) # 可以转化成list
print(l1)
for key in dic1.keys(): # 可以遍历(查看)
print(key)
结果为:
dict_keys(['name', 'age', 'sex']) <class 'dict_keys'> ['name', 'age', 'sex'] name
age
sex

方法四:

# (4)values方法
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
print(dic1.values()) # 可以转化成list ,可以遍历(查看)
print(list(dic1.values()))
结果为:
dict_values(['太白', 25, 'M'])
['太白', 25, 'M']

方法五:

# (4)items方法
dic1 = {'name': '太白', 'age': 25, 'sex': 'M'}
print(dic1.items()) # 可以转化为list ,可遍历(查看)
print(list(dic1.items()))
for k, v in dic1.items():
print(k, v) # 分别赋值
结果为:
dict_items([('name', '太白'), ('age', 25), ('sex', 'M')])
[('name', '太白'), ('age', 25), ('sex', 'M')]
name 太白
age 25
sex M

六、分别赋值

# 分别赋值     # 面试题
a , b = 10,20
a ,b = b,a
print(a,b) 结果为:
20 10

Python基础学习Day5 字典的增、删、改、查的用法 分别赋值的更多相关文章

  1. 好用的SQL TVP~~独家赠送[增-删-改-查]的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  2. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  3. iOS FMDB的使用(增,删,改,查,sqlite存取图片)

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  4. iOS sqlite3 的基本使用(增 删 改 查)

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  5. ADO.NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...

  6. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  7. python基础中的四大天王-增-删-改-查

    列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...

  8. python基础学习笔记——字典

    字典(Dictionary) 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值 key=>value 对用冒号 : 分割,每个键值对之间用逗号 , 分割,整个字典包括在花括号 { ...

  9. Python 基础学习之字典

    1.基础代码 ##第六章 字典学习 test={'} print(test['a']) print(test['b']) 返回结果为: black123 2.基础知识: Python中的字典是一系列键 ...

随机推荐

  1. 《Linux 性能及调优指南》2.3 监控工具

    翻译:飞哥 (http://hi.baidu.com/imlidapeng) 版权所有,尊重他人劳动成果,转载时请注明作者和原始出处及本声明. 原文名称:<Linux Performance a ...

  2. 高德地图打包后不能使用,高德导航View不显示,高德地图导航组件黑屏的问题;

    在现在的APP中地图真的很常见,我们在去使用是一般都会选择一些三方的API,像百度.高德等等... 在集成的过程中,难免会遇到一些问题,大部分问题我们仔细的阅读开发文档都能解决的:但是!!!问题出现后 ...

  3. websocket如何设置?

    根据之前写的步骤到当前的websocket设置 一.websocket设置: 1)在线程租下右键单击选择Sampler如图: 2)进行它的设置 2.保存 3.添加查看结果数和聚合报告(此处不详细说明, ...

  4. 背景图片的移动----background-attach-----background-repeat

    background-repeat:默认是平铺的,也即是还有空间的话将一张接着一张显示 设置为 no-repeat  就最多显示一张 background-attachment:设置是否固定图片,在有 ...

  5. centos离线安装docker及其它软件包

    桌面版本安装 docker可以通过网络安装,但在内网环境,需要进行离线安装. 执行 uname -r 获取操作系统版本号 根据版本号,到docker.com下载docker的离线安装包: Linux版 ...

  6. Java-1.6-并发包-集合

    List相关 对于List并发包就只扩展了一个CopyOnWriteArrayList<E> Set相关 对于Set,并发包扩展ConcurrentSkipListSet<E> ...

  7. val和var和Java

    object Hello { def main(args :Array[String]) { val k = i } } jvm代码 public final class Hello$ { publi ...

  8. zookeeper(5)--基于watcher原理实现带注册中心的RPC框架

    一.带版本控制的注册中心RPC框架 server端 //注册中心接口 public interface IRegisterCenter { public void register(String se ...

  9. ribbbitMq 教程,详细

    https://blog.csdn.net/hellozpc/article/details/81436980

  10. leetcode993

    public class Node { public int CurNode; public int FatherNode; public int Layer; } public class Solu ...