字典是另一种可变容器模型,且可存储任意类型对象,下标从0开始,最后一个为-1。

字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格式如下所示:

d = {key1 : value1, key2 : value2 }

键必须是唯一的,但值则不必,字典是无序的。

值可以取任何数据类型,但键必须是不可变的,如字符串,数字或元组。

一个简单的字典实例:

dict = {'aaa': '', 'bb': '', 'ccc': ''}

也可如此创建字典:

dict1 = { 'ddd': 1234 };
dict2 = { 'ddd': 1235, 98.6: 37 };

1. 增加

d['height'] = 170
d.setdefault('age','21') #显示d这个字典的'age'值的内容,因为字典有,所以不会去设置它
 #字典: key-value, 取值方便,速度快,key不能重复
d = {'name':'nancy',
'age':'',
'sex':'female',
'addr': 'nb'
}
#增加
d['height'] = 170
print(d) # -> {'sex': 'female', 'age': '20', 'name': 'nancy', 'height': 170, 'addr': 'nb'}
#字典是无序的
value = d.setdefault('age','') #显示d这个字典的'age'值的内容,因为字典有,所以不会去设置它
print(value) #
value1 = d.setdefault('weight',98) ##显示d这个字典的'weight'值的内容,因为字典没有,所以设置为98了
print(value1) #-> 98
print(d) # -> {'height': 170, 'name': 'nancy', 'age': '20', 'addr': 'nb', 'sex': 'female', 'weight': 98}

2. 删除

d.pop('height')#删除某个key,这个比较常用
d.popitem() # 随机删除一个
del d['name']#删除某个key
d.clear()#清空字典
 #字典: key-value, 取值方便,速度快,key不能重复
d = {'name':'nancy',
'age':'',
'sex':'female',
'addr': 'China',
'height': ''
}
#删除
d.pop('height')#删除某个key,这个比较常用
print(d) # -> {'sex': 'female', 'age': '20', 'name': 'nancy', 'addr': 'China'}
d.popitem() # 随机删除一个
print(d) #-> {'age': '20', 'name': 'nancy', 'addr': 'China'}
del d['name']#删除某个key
print(d) # -> {'sex': 'female', 'addr': 'China'}
d.clear()#清空字典
print(d) # -> {}

3. 修改

d['height'] = 170 #如果key 存在的话,修改它的值,如果不存在的话新增
 #字典: key-value, 取值方便,速度快,key不能重复
d = {'name':'nancy',
'age':'',
'sex':'female',
'addr': 'China',
'height': ''
}
#修改
d['height'] = 170 #如果key 存在的话,修改它的值,如果不存在的话新增
print(d) # -> {'addr': 'China', 'name': 'nancy', 'height': 170, 'age': '20', 'sex': 'female'}

4. 查看

通过方括号[]取值查看

 #字典: key-value, 取值方便,速度快,key不能重复
d = {'name':'nancy',
'age':'',
'sex':'female',
'addr': 'China',
'height': ''
}
#查看
print(d['name'])#如果写了不存在的key,会报错 -> nancy
print(d['age']) # -> 20
print(d.get('addr')) # -> China
print(d.get('addr1'))#如果get()不到的话,返回None -> None
print(d.get('addr2','找不到')) # -> 找不到
print(d.keys())#取得所有的key -> dict_keys(['age', 'addr', 'height', 'name', 'sex'])
print(d.values())#获得所有的value -> dict_values(['20', 'China', '180', 'nancy', 'female'])
#d.has_key('addr')#python2 里面有这个方法,python3里没有
if 'addr' in d: #判断key 是否在这个字典里
print('addr') # -> addr
#if 'addr' in d.keys():
 for k in d: #取到key
print(k) # 打印所有的key值 print(d.items())#是把字典的key,value 转成一个二维数组(实际上不是真的二维数组,要使用需强制转换),性能不好
# -> dict_items([('height', '180'), ('sex', 'female'), ('addr', 'China'), ('age', '20'), ('name', 'nancy')])
res = list(d.items())
print(res[0]) # ->('height','180') for k,v in d.items():#可以同时把key 和value 取出来
print(k,v)
#height 180
#sex female
#addr China
#age 20
#name nancy for k in d:#性能好,保留了字典原有的特性
print(k,d.get(k))
# height 180
# sex female
# addr China
# age 20
# name nancy

python 中字典的操作(增、删、改、查)的更多相关文章

  1. django单表操作 增 删 改 查

    一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...

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

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

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

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

  4. django ajax增 删 改 查

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

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

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

  6. ADO.NET 增 删 改 查

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

  7. MVC EF 增 删 改 查

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

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

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

  9. MongoDB增 删 改 查

    增 增加单篇文档 > db.stu.insert({sn:'001', name:'lisi'}) WriteResult({ "nInserted" : 1 }) > ...

随机推荐

  1. tp 批量转码

    读取王正东成功,然后把乱码一条一条的改回来... 专门针对mssql数据库的!!!

  2. java深度搜索与广度优先搜索

    图结构展示: 实现过程: 首先,我们来看看图结构在代码中的实现.有三块逻辑: 1.图中的节点: public class GraphNode { public List<GraphEdge> ...

  3. mysql插入多行数据

    表结构如图:

  4. AWS系列-复制AMI到其他区域

    复制AMI镜像到其他区域 1.1 打开EC2控制面板,找到AMI 选择需要迁移的AMI 1.2 选择复制的目标区域 选择复制到目标区域 我这里是 东京复制到新加坡 1.3 点击完成后,切换到相应的区域 ...

  5. 提高ASP.NET网站性能的方法

    http://www.360doc.com/content/14/0705/18/7662927_392224856.shtml   Asp.NET有许多秘密,当你了解了这些秘密后,可以使得你的ASP ...

  6. Codeforces Round #296 (Div. 2) B. Error Correct System

    B. Error Correct System time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  7. UE打包32位程序遇到Win32 is not a supported platform for MindWaveEditor. Valid platforms are Win64.

    1>------ 已启动全部重新生成: 项目: MindWave, 配置: Development_Editor Win32 ------1> Win32 is not a support ...

  8. Spring学习笔记 7.1 Spring MVC起步

    7.1.1 跟踪Spring MVC的请求请求首先到达DispatcherServlet(DispatcherServlet是Spring MVC中的前端控制器):DispatcherServlet的 ...

  9. 160603、使用pd4ml.jar和ss_css2.jar转pdf的工具类

    注意:需要导入pd4ml.jar和ss_css2.jar import java.awt.Insets;import java.io.BufferedInputStream;import java.i ...

  10. 制作item和category的mvc视图总结

    View层index.phg 代码: <?php use yii\helpers\Html; use yii\grid\GridView; use yii\widgets\Pjax; use f ...