python数据字典ppt_python数据字典的操作

本文详细介绍了Python字典的数据结构特性,包括字典的创建、访问、更新和删除操作,以及字典与其他类型的区别。同时,阐述了字典的遍历方式和注意事项,并提供了具体的代码示例,展示了如何在实际应用中使用字典。此外,还提到了字典在数据库操作中的作用。
摘要由CSDN通过智能技术生成

一、什么是字典?

字典是Python语言中唯一的映射类型。

映射类型对象里哈希值(键,key)和指向的对象(值,value)是一对多的的关系,通常被认为是可变的哈希表。

字典对象是可变的,它是一个容器类型,能存储任意个数的Python对象,其中也可包括其他容器类型。

字典类型与序列类型的区别:

1.存取和访问数据的方式不同。

2.序列类型只用数字类型的键(从序列的开始按数值顺序索引);

3.映射类型可以用其他对象类型作键(如:数字、字符串、元祖,一般用字符串作键),和序列类型的键不同,映射类型的键直接或间接地和存储数据值相关联。

4.映射类型中的数据是无序排列的。这和序列类型是不一样的,序列类型是以数值序排列的。

5.映射类型用键直接“映射”到值。

字典是Python中最强大的数据类型之一。

二、如何创建字典和给字典赋值

简单地说字典就是用大括号包裹的键值对的集合。(键值对也被称作项)

一般形式:

id_db = {'wang':{

'name':"delong",

'age':31,

"addr":'juye'},

'liu':{

'name':"jun",

'age':42,

"addr":'shanghai'},

'wan':{

'name':"li",

'age':18,

"addr":'biyang'},

}

特点:

1、键与值用冒号“:”分开;

2、项与项用逗号“,”分开;

3、字典中的键必须是唯一的,而值可以不唯一。

三、字典的基本操作

1、如何访问字典中的值?

adict[key] 形式返回键key对应的值value,如果key不在字典中会引发一个KeyError。

2、如何检查key是否在字典中?

a、has_key()方法 形如:adict.haskey(‘name') 有–>True,无–>False

b、in 、not in   形如:'name' in adict      有–>True,无–>False

3、如何更新字典?

a、添加一个数据项(新元素)或键值对

adict[new_key] = value 形式添加一个项

b、更新一个数据项(元素)或键值对

adict[old_key] = new_value

c、删除一个数据项(元素)或键值对

del adict[key] 删除键key的项 / del adict 删除整个字典

adict.pop(key) 删除键key的项并返回key对应的 value值

四、映射类型操作符

标准类型操作符(+,-,*,,<=,>=,==,!=,and,or, not)

a、字典不支持拼接和重复操作符(+,*)

b、字典的比较操作

先比较字典的长度也就是字典的元素个数

键比较

值比较

五、映射相关的函数

1、len() 返回字典的长度

2、hash() 返回对象的哈希值,可以用来判断一个对象能否用来作为字典的键

3、dict() 工厂函数,用来创建字典

六、字典的方法

1、adict.keys() 返回一个包含字典所有KEY的列表;

2、adict.values() 返回一个包含字典所有value的列表;

3、adict.items() 返回一个包含所有(键,值)元祖的列表;

4、adict.clear() 删除字典中的所有项或元素;

5、adict.copy() 返回一个字典浅拷贝的副本;

6、adict.fromkeys(seq, val=None) 创建并返回一个新字典,以seq中的元素做该字典的键,val做该字典中所有键对应的初始值(默认为None);

7、adict.get(key, default = None) 返回字典中key对应的值,若key不存在字典中,则返回default的值(default默认为None);

8、adict.has_key(key) 如果key在字典中,返回True,否则返回False。 现在用 in 、 not in;

9、adict.iteritems()、adict.iterkeys()、adict.itervalues() 与它们对应的非迭代方法一样,不同的是它们返回一个迭代子,而不是一个列表;

10、adict.pop(key[,default]) 和get方法相似。如果字典中存在key,删除并返回key对应的vuale;如果key不存在,且没有给出default的值,则引发keyerror异常;

11、adict.setdefault(key, default=None) 和set()方法相似,但如果字典中不存在Key键,由 adict[key] = default 为它赋值;

12、adict.update(bdict) 将字典bdict的键值对添加到字典adict中。

七、字典的遍历

1、遍历字典的key(键)

for key in adict.keys():print key

2、遍历字典的value(值)

for value in adict.values(): print value

3、遍历字典的项(元素)

for item in adict.items():print item

4、遍历字典的key-value

for item,value in adict.items(): print ‘key=%s, value=%s' %(item, value) 或 for item,value in adict.iteritems(): print ‘key=%s, value=%s' %(item, value)

注意:for item,value in adict.items(): print ‘key=%s', ‘value=%s', %(item, value) 这种写法是错误的

八、使用字典的注意事项

1、不能允许一键对应多个值;

2、键必须是可哈希的。

具体的应用实例:

#获取字典,数据字典有天然去重的功能,字典是无序的。

id_db = {'wang':{

'name':"delong",

'age':31,

"addr":'juye'},

'liu':{

'name':"jun",

'age':42,

"addr":'shanghai'},

'wan':{

'name':"li",

'age':18,

"addr":'biyang'},

}

print(id_db)

print(id_db["wan"]) #打印一个key对应的value

id_db["wan"]["name"]="wanli" #修改一个对应的value,的值

print(id_db["wan"]) #打印一个key对应的value

id_db["wan"]["qq"]=28776 #添加一个新的value对应的值

print(id_db["wan"]) #打印一个key对应的value

id_db["wan"].pop("age")#删除一个value的值

print(id_db["wan"])

v=id_db.get("liu") #获取一个key对应的值

print(v)

v=id_db.get("") #获取一个key对应的值,当不存在时为None

vv =id("liu") #这样也可以,但是如果没有时会报错,建议用get方法获取

print(v)

print(id_db.keys()) #获取数据字典里面所有的key,转换成列表

print(id_db.values()) #打印所有的value,转换成列表

id_db["zhao"]={"name":"wanli"} #添加一个键,并为这个键赋值

id_db = {'wang':{

'name':"delong",

'age':31,

"addr":'juye'},

'liu':{

'name':"jun",

'age':42,

"addr":'shanghai'},

'wan':{

'name':"li",

'age':18,

"addr":'biyang'},

}

d_db2 ={ "naem":"ddddddddd",

'wan':{ 'name':"liwan",

}

}

id_db.update(d_db2) #把d_db2的内容更新到id_db里面去,如果id_db 有相同的内容会进行更细,没有回添加,注意如果有相同的key,会同步d_db2的内容

print(id_db)

print(id_db.items()) #把字典变成列表,但如果字典数据量大的时候不要做这种事情,转换很耗时间

"wang" in id_db #查看是否包含着key

print(id_db.setdefault("naem")) #如果存在就取出,不存在就添加一个key,kye的值是Noey

print(id_db.setdefault("wangdeeee")) #如果存在就取出,不存在就添加一个key,kye的值是None

print(id_db.setdefault("wangde","wdbdfbeebeb")) #如果存在就取出,不存在就添加一个key,给他附一个值values

print(dict.fromkeys([1,2,3,4,5,6,7],"dddd")) #把列表里面的按照顺序取出来,当做key,把后面的东西当做values

print(id_db.popitem()) #随机删除一个值,是随机删除没有顺序

print(id_db)

循环:

id_db = {'wang':{

'name':"delong",

'age':31,

"addr":'juye'},

'liu':{

'name':"jun",

'age':42,

"addr":'shanghai'},

'wan':{

'name':"li",

'age':18,

"addr":'biyang'},

}

d_db2 ={ "naem":"ddddddddd",

'wan':{ 'name':"liwan",

}

}

for k,v in id_db.items():#效率低,因为有一个转换过程,dict 转list

print(k,v)

for key in id_db: #效率高的用法

print(key,id_db[key])

for key in enumerate(id_db): #增加key序列选项,序列是下标值

print("%s:%s" % key)

python高级之操作数据库

python高级之操作数据库 本节内容 pymysql介绍及安装 使用pymysql执行sql 获取新建数据自增ID fetch数据类型设置 1.pymysql介绍及安装 在python2中连接数据库 ...

Python 文件常见操作

# -*-coding:utf8 -*- ''''' Python常见文件操作示例 os.path 模块中的路径名访问函数 分隔 basename() 去掉目录路径, 返回文件名 dirname()  ...

Python &colon;open文件操作&comma;配合read&lpar;&rpar;使用!

python:open/文件操作 open/文件操作f=open('/tmp/hello','w') #open(路径+文件名,读写模式) 如何打开文件 handle=open(file_name,a ...

第九篇:python高级之操作数据库

python高级之操作数据库   python高级之操作数据库 本节内容 pymysql介绍及安装 使用pymysql执行sql 获取新建数据自增ID fetch数据类型设置 1.pymysql介绍及 ...

(转载)Python 列表&lpar;list&rpar;操作

(转载)http://blog.csdn.net/facevoid/article/details/5338048 创建列表sample_list = ['a',1,('a','b')] Python ...

python之数据库操作&lpar;sqlite&rpar;

python之数据库操作(sqlite) 不像常见的客户端/服务器结构范例,SQLite引擎不是个程序与之通信的独立进程,而是连接到程序中成为它的一个主要部分.所以主要的通信协议是在编程语言内的直接A ...

python通过openpyxl操作excel

python 对Excel操作常用的主要有xlwt.xlrd.openpyxl ,前者xlwt主要适合于对后缀为xls比较进行写入,而openpyxl主要是针对于Excel 2007 以上版本进行操作 ...

python操作三大主流数据库&lpar;8&rpar;python操作mongodb数据库②python使用pymongo操作mongodb的增删改查

python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...

python sqlite3 数据库操作

python sqlite3 数据库操作 SQLite3是python的内置模块,是一款非常小巧的嵌入式开源数据库软件. 1. 导入Python SQLite数据库模块 import sqlite3 ...

随机推荐

SQL SERVER2005 的三种复制类型概述

一.事务复制 事务性复制通常从发布数据库对象和数据的快照开始.创建了初始快照后,接着在发布服务器上所做的数据更改和架构修改通常在修改发生时(几乎实时)便传递给订阅服务器.数据更改将按照其在发布服务器上 ...

tulterbot遥感操作使用Interactive Markers--12

原创博客:转载请表明出处:http://www.cnblogs.com/zxouxuewei/ 1.安装ros indigo功能包: sudo apt-get install ros-indigo-t ...

xpage 获取 附件

var db:NotesDatabase=session.getCurrentDatabase(); var doc:NotesDocument=db.getDocumentByUNID('80E21 ...

新学python画一个爱心

from turtle import * def curvemove(): for i in range(200): right(1) forward(1) color('yellow','red') ...

通过DataTable获得表的主键

转载http://www.cnblogs.com/hobe/archive/2005/10/07/249940.html 通过DataTable获得表的主键 很多情形下我们需要知道表的主键是什么.在A ...

&lbrack;转&rsqb;Tomcat中的Session小结

阅读目录 什么是Session Session的目的 实现机制 Tomcat中的session实现 session存在的问题 什么是Session 对Tomcat而言,Session是一块在服务器开辟 ...

WebClient类

WebClient类提供向 URI 标识的资源发送数据和从 URI 标识的资源接收数据的公共方法. 其实就相当于创建一个请求客户端.可以获取网页和各种各样的信息,包括交互. 通过MSDN来看看WebC ...

20145315 《Java程序设计》第六周学习总结

20145315 第六周学习总结 教材学习内容总结 第十章:输入输出 10.1.1 数据有来源与目的,衔接两者的是串流对象. read()方法每次尝试读取数据,并返回实 ...

DPDK硬件盒子的初步安装测试

DPDK硬件盒子 接口 两个USB接口:用于连接键盘等. HDMI接口:高清晰度多媒体接口,用于连接显示器,但是一般的电脑显示器使用的是VGA口,可以用一个转接头连接. 两个RJ接口:可接入网线连接. ...

使用分治法求X的N次方,时间效率为lgN

最近在看MIT的算法公开课,讲到分治法的求X的N次方时,只提供了数学思想,于是自己把代码写了下,虽然很简单,还是想动手写一写. int powerN(int x,int n){ if(n==0){ r ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值