一、字典的定义与创建

字典是Python中唯一内建的映射类型。你可以将其想象成书本的目录,章节名称代表“key”,页码则代表“value”。书本的目录本质上是也是字典。

1、字典的创建

(1)下面通过一个实例引入字典:

使用列表构建包含姓名和电话号码的数据库

names = ['aa','bb','cc','dd','ee','ff']
numbers = [123,456,789,'',131415,161718]
name = input("please enter your name :")
print(numbers[names.index(name)])

使用字典构建包含姓名和电话号码的数据库

info = {
'aa':123,
'bb':456,
'cc':789,
'dd':"",
'ee':131415,
'ff':161718
}
print(info[input("please enter your name :")])

字典由多个键值对组成,键值对也称为“项”,字典的特性:键是唯一的,值不唯一

(2) 使用dict函数创建字典

items =[('zhangsan',18),('lisi',19),('wangwu',20)]
item = dict(items)
print(item)

2、字典常用基本操作

字典基本操作:len,d[key],d[k]=v,del d[k],k in d

#计算字典键值对数量
test = {
'aa':123,
'bb':456,
'cc':789,
'dd':"",
'ee':131415,
'ff':161718
}
print(len(test))
#d[key],获取指定key的值
print(test['bb'])
#d[k]=v,修改指定key的value
test['ff']=111111111
print(test)
#del d[k] 删除指定键的元素
del(test['ff'])
print(test)
#k in d,查找某个键是否在字典中存在
print('dd' in test)
#简单数据库:每个人的手机号和地址
people={
'zhangsan':{
'phone':13966137218,
'addr':'上海市浦东新区源深路419号国际华城'
},
'lisi':{
'phone':13511983857,
'addr':'上海市松江区人民南路323号'
},
'wanwu':{
'phone':18339484093,
'addr':'上海市宝山区韶山路221号'
}
}
#手机号及地址使用的描述性标签,用于打印输出
labels ={
'phone':'phone number',
'addr':'address'
}
name =input("Your name :")
#查询手机号还是地址
req=input('Phone number please enter \'p\';Address please enter \'a\'')
if req == 'p':
key='phone'
elif req == 'a':
key='addr'
else:
print("Sorry,your enter is wrong")
if name in people: print ("%s 's %s is %s ." % (name,labels[key],people[name][key]))

3、字典基本方法

字典常用方法:clear,copy,fromkeys,get,items,keys,pop,popitem,setdefault,update,values

(1) clear  清空字典

x={}
y=x
x['key']='value'
print(x)
print(y)
x.clear()
print(y)
"""
{'key': 'value'}
{'key': 'value'}
{}
"""

(2) copy

#copy  返回一个具有相同键值对的新字典(浅复制)
a={'a':1,'b':['','','']}
b=a.copy()
#若在副本中修改值,原字典不受影响
b['a']='aaa'
#若在副本中增删值,原字典会跟着改变
b['b'].remove('')
print(a)
print(b)
"""
{'a': 1, 'b': ['2', '3']}
{'a': 'aaa', 'b': ['2', '3']}
"""
#deepcopy  深复制,原字典改变,副本不变;副本改变,原字典也不变;原字典与副本都单独开辟了内存空间
from copy import deepcopy
c={'a':1,'b':['','','']}
d=deepcopy(c)
c["b"].append('')
print(c)
print(d)
print(id(c))
print(id(d))
e=deepcopy(c)
e["b"].append("")
print(c)
print(e)
print(id(c))
print(id(e))
"""
{'a': 1, 'b': ['2', '3', '4', '5555555']}
{'a': 1, 'b': ['2', '3', '4']}
38559608
38597040
{'a': 1, 'b': ['2', '3', '4', '5555555']}
{'a': 1, 'b': ['2', '3', '4', '5555555', '666666666666']}
38559608
38597112
"""

(3)  fromkeys

#fromkeys  使用指定的键创建新字典,每个键对应的value默认为None
print({}.fromkeys(['zhangsan','lisi']))
#{'zhangsan': None, 'lisi': None}
#自己提供默认值
print({}.fromkeys(['zhangsan','lisi'],''))
"""
#fromkeys 使用指定的键创建新字典,每个键对应的value默认为None
print({}.fromkeys(['zhangsan','lisi']))
#{'zhangsan': None, 'lisi': None}
#自己提供默认值
print({}.fromkeys(['zhangsan','lisi'],'666'))
"""

(4)get

#get   根据key,获取value。key不存在时,返回None(可自定义默认值替换None)而不会报错b
age ={
'zs':12,
'ls':15,
'ww':18
}
print(age.get('ww'))
print(age.get('zl'))
print(age.get('zl','NA'))
"""
18
None
NA
"""

(5)items

#items  以列表的方式返回字典的所有键值对
pp ={
'zs':12,
'ls':15,
'ww':18
}
print(pp.items())
"""
dict_items([('zs', 12), ('ls', 15), ('ww', 18)])
"""

(6) keys values

#keys  以列表的形式返回字典的所有key;values  返回字典的所有values
print(pp.keys())
print(pp.values())
"""
dict_keys(['zs', 'ls', 'ww'])
dict_values([12, 15, 18])
"""

(7)  pop

#pop  弹出(删除)字典中指定key的元素
pp.pop("zs")
print(pp)
pp.pop("ls")
print(pp)
"""
{'ls': 15, 'ww': 18}
{'ww': 18}
"""

(8)  popitem

#popitem  随机弹出字典中的某个项
qq ={
'zs': 12,
'ls': 15,
'ww': 18
}
qq.popitem()
print(qq)
"""
{'zs': 12, 'ls': 15}
"""

(9)  setdefault

#setdefault  获取字典中某个Key的value,类似于get,若key不存在,则创建指定默认值
print("********************")
t={}
t.setdefault("name","zhangsan")
print(t)
print(t.setdefault("name"))

(10)  update

#update  将两个字典合并,如果key相同,则更新原字典
m={
'a':1,
'b':2
}
n={
'c':3,
'd':4
}
m.update(n)
print(m) d={
'tittle':'Python Web Site',
'url':'http://www.python.org',
'changed':'DDD'
}
x={'tittle':'Python Language Website'}
d.update(x)
print(d)
"""
{'a': 1, 'b': 2, 'c': 3, 'd': 4}
{'tittle

问题思考:请详细分析以下很“low”的代码。

x={}
y=x
print(x)
print(y)
x['a']=1
print(x)
print(y)
x={}
print(x)
print(y)

Python成长之路 — 字典的更多相关文章

  1. 【Python成长之路】Python爬虫 --requests库爬取网站乱码(\xe4\xb8\xb0\xe5\xa)的解决方法【华为云分享】

    [写在前面] 在用requests库对自己的CSDN个人博客(https://blog.csdn.net/yuzipeng)进行爬取时,发现乱码报错(\xe4\xb8\xb0\xe5\xaf\x8c\ ...

  2. (转)Python成长之路【第九篇】:Python基础之面向对象

    一.三大编程范式 正本清源一:有人说,函数式编程就是用函数编程-->错误1 编程范式即编程的方法论,标识一种编程风格 大家学习了基本的Python语法后,大家就可以写Python代码了,然后每个 ...

  3. 【Python成长之路】装逼的一行代码:快速共享文件

    [Python成长之路]装逼的一行代码:快速共享文件 2019-10-26 15:30:05 华为云 阅读数 335 文章标签: Python编程编程语言程序员Python开发 更多 分类专栏: 技术 ...

  4. python成长之路第三篇(1)_初识函数

    目录: 函数 为什么要使用函数 什么是函数 函数的返回值 文档化函数 函数传参数 文件操作(二) 1.文件操作的步骤 2.文件的内置方法 函数: 一.为什么要使用函数 在日常写代码中,我们会发现有很多 ...

  5. 我的Python成长之路---第一天---Python基础(1)---2015年12月26日(雾霾)

    2015年12月26日是个特别的日子,我的Python成之路迈出第一步.见到了心目中的Python大神(Alex),也认识到了新的志向相投的伙伴,非常开心. 尽管之前看过一些Python的视频.书,算 ...

  6. Python成长之路第一篇(3)_初识字典

    经过上章的学习我们已经了解到了列表可以通过索引来获取对应的值,在本章我们将学到通过名字来索引数据,这种结构的类型称之为映射(maooing),在Python中字典是唯一内建的映射类型,其中的值我们称之 ...

  7. Python成长之路第二篇(3)_字典的置函数用法

    字典的置函数用法(字典dict字典中的key不可以重复) class dict(object): """ dict() -> new empty dictionar ...

  8. python成长之路七-函数的进阶

    1,python中,名称空间分三种: 全局命名空间 局部命名空间(临时命名空间) 内置名称空间 2,作用域(两种): 1,全局作用域  包含:全局名称空间   内置名称空间 2,局部作用域  包含:局 ...

  9. python成长之路【第十五篇】:JavaScript初步认识

    JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处理. 一.如何编写 1.J ...

随机推荐

  1. LINQ to XML编程之编程基础

    1.声明,LINQ to XML让xml的创建变得非常简单. XDocument myDocument = new XDocument( new XDeclaration("1.0" ...

  2. 原生JS中DOM节点相关API合集

    节点属性 Node.nodeName //返回节点名称,只读 Node.nodeType //返回节点类型的常数值,只读 Node.nodeValue //返回Text或Comment节点的文本值,只 ...

  3. 读书笔记 effective c++ Item 53 关注编译器发出的警告

    许多程序员常常忽略编译器发出的警告.毕竟,如果问题很严重,它才将会变成一个error,不是么?相对来说,这个想法可能在其它语言是无害的,但是在C++中,我敢打赌编译器的实现者对于对接下来会发生什么比你 ...

  4. Angular2.js——数据显示

    显示数据,即属性绑定机制把数据显示到用户界面上. 在Angular中最典型的数据显示方式,就是把HTML模板中的控件绑定到Angular组件的属性. 接下来介绍几种数据显示的语法和代码片段. 使用插值 ...

  5. 由CODEVS笨小猴1053引发的一些思考

    #include<cstdio> #include<cstring> ]; ]; int check(int n) { ||n==) ; ;m*m<=n;++m) ) ; ...

  6. mysql分页查询优化

    由于MySql的分页机制:并不是跳过 offset 行,而是取 offset + N 行,然后返回放弃前 offset 行,返回N 行, 所以当 offset 特别大的时候,效率就非常的低下,要么控制 ...

  7. 从零开始构建一个的asp.net Core 项目

    最近突发奇想,想从零开始构建一个Core的MVC项目,于是开始了构建过程. 首先我们添加一个空的CORE下的MVC项目,创建完成之后我们运行一下(Ctrl +F5).我们会在页面上看到"He ...

  8. 如何使用angular-ui的弹出框

    在开发项目时,我们经常性的会遇到弹出框的需求,例如登陆,注册,添加信息等等....面对这一需求,我们当然也可以使用自己的双手进行编写,如果你时间充足可以试试. 今天我们讲解一下如何在angular框架 ...

  9. [刷题]ACM/ICPC 2016北京赛站网络赛 第1题 第3题

    第一次玩ACM...有点小紧张小兴奋.这题目好难啊,只是网赛就这么难...只把最简单的两题做出来了. 题目1: 代码: //#define _ACM_ #include<iostream> ...

  10. PS不能存储,因为程序错误

    当PS中遇到不能存储文件,因为程序错误时,可以这样: http://www.zcool.com.cn/article/ZMTgwOTQw.html