python基础:zip和dict详解
一.zip函数:接受任意多个(包括0个和1个)序列作为参数,返回一个tuple列表。
1.示例1:
![](/assets/blank.gif)
x = [1, 2, 3]y = [4, 5, 6]z = [7, 8, 9]xyz = zip(x, y, z)print xyz
![](/assets/blank.gif)
运行的结果是:
[(1, 4, 7), (2, 5, 8), (3, 6, 9)]
从这个结果可以看出zip函数的基本运作方式。
2.示例2:
x = [1, 2, 3] y = [4, 5, 6, 7] xy = zip(x, y) print xy
运行的结果是:
[(1, 4), (2, 5), (3, 6)]
从这个结果可以看出zip函数的长度处理方式。
3.示例3:
x = [1, 2, 3] x = zip(x) print x
运行的结果是:
[(1,), (2,), (3,)]
从这个结果可以看出zip函数在只有一个参数时运作的方式。
4.示例4:
x = zip() print x
运行的结果是:
[]
从这个结果可以看出zip函数在没有参数时运作的方式。
5.示例5:
![](/assets/blank.gif)
x = [1, 2, 3]y = [4, 5, 6]z = [7, 8, 9]xyz = zip(x, y, z)u = zip(*xyz)print u
![](/assets/blank.gif)
运行的结果是:
[(1, 2, 3), (4, 5, 6), (7, 8, 9)]
一般认为这是一个unzip的过程,它的运行机制是这样的:
在运行zip(*xyz)之前,xyz的值是:[(1, 4, 7), (2, 5, 8), (3, 6, 9)]
那么,zip(*xyz) 等价于 zip((1, 4, 7), (2, 5, 8), (3, 6, 9))
所以,运行结果是:[(1, 2, 3), (4, 5, 6), (7, 8, 9)]
注:在函数调用中使用*list/tuple的方式表示将list/tuple分开,作为位置参数传递给对应函数(前提是对应函数支持不定个数的位置参数)
6.示例6:
x = [1, 2, 3] r = zip(* [x] * 3) print r
运行的结果是:
[(1, 1, 1), (2, 2, 2), (3, 3, 3)]
它的运行机制是这样的:
[x]生成一个列表的列表,它只有一个元素x
[x] * 3生成一个列表的列表,它有3个元素,[x, x, x]
zip(* [x] * 3)的意思就明确了,zip(x, x, x)
二、dict操作
1、使用zip创建字典
key = 'abcde'
value = range(1, 6)
dict(zip(key, value))
2、使用items()来遍历字典
for key,value in d.items():
3.使用get, pop来获取/删除key
首先,dict[key] 与 delete dict[key]也可以获取/删除key。但是key不存在时,会引发 KeyError 异常。为了避免引发异常可以使用带defaut参数的get和pop函数
- get(key[, default])
如果key在字典中,返回对应的value, 否则返回default。所以从来不会引发异常。 - pop(key[, default])
如果default未设置,则如果key不在字典中,删除key将引发异常。使用时加上default。
4、dict(dict1, **dict2)合并两个字典
合并两个字典可以先把两个字典分成key-value对,再连接两个key-value对,生成新的字典。即 dict(dict1.items()+dict2.items())
,不过效率有些低。
使用效率更高的 dict(dict1, **dict2)
连接两个字典。如果dict1与dict2含有相同的key,那么dict2的value会覆盖dict1
![](/assets/blank.gif)
![](/assets/blank.gif)
1 dict1 = {"a" : "apple", "b" : "banana"} 2 print(dict1) 3 dict2 = {"a" : "grape", "d" : "orange"} 4 print(dict(dict1,**dict2)) 5 #输出 6 #{'a': 'apple', 'b': 'banana'} 7 #{'a': 'grape', 'b': 'banana', 'd': 'orange'}
View Code
5、使用keys()和values()获取关键词和值
d.keys()
d.values()
6、使用update()更新字典,与4的dict(dict1, **dict2)效果一样,如果dict1与dict2含有相同的key,那么dict2的value会覆盖dict1
![](/assets/blank.gif)
![](/assets/blank.gif)
1 dict1 = {"a" : "apple", "b" : "banana"} 2 print(dict1) 3 dict2 = {"c" : "grape", "d" : "orange"} 4 dict1.update(dict2) 5 print(dict1)
View Code
输出:
{'a': 'apple', 'b': 'banana'}
{'c': 'grape', 'a': 'apple', 'b': 'banana', 'd': 'orange'}
7、使用sorted排序
#按照key排序print(sorted(dict1.items(), key=lambda d: d[0]))#按照value排序print(sorted(dict1.items(), key=lambda d: d[1]))
8、使用setdefault设置默认值
dict = {}
dict.setdefault("a")
9、pop()和clear()删除
![](/assets/blank.gif)
![](/assets/blank.gif)
1 d={"a":1,"b":2,"c":3} 2 print(d) 3 #输出 4 #{"a":1,"b":2,"c":3} 5 6 d1=d.pop("a") #d1=1 7 print(d) 8 #输出 9 #{"b":2,"c":3} 10 11 d2=d.pop("f",100) #d2=100 12 print(d) 13 #输出 14 #{"b":2,"c":3}
View Code
d.clear() #将字典d清空
print(d) #输出{}
10、使用fromkeys() 函数用于创建一个新字典,以序列seq中元素做字典的键,value为字典所有键对应的初始值。
![](/assets/blank.gif)
![](/assets/blank.gif)
1 seq={'name','age','score'} 2 d=dict.fromkeys(seq,100) 3 print(d) 4 #输出 5 #{'name': 100, 'age': 100, 'score': 100}
View Code
11、使用popitems()随机返回并删除字典中的一对键和值(项)
![](/assets/blank.gif)
![](/assets/blank.gif)
1 seq={'name','age','score'} 2 d=dict.fromkeys(seq,100) 3 print(d) #输出:{'age': 100, 'name': 100, 'score': 100} 4 d2=d.popitem() 5 print(d2) #输出:('age', 100) 6 print(d) #输出:{'name': 100, 'score': 100}
View Code
转载于:https://www.cnblogs.com/yizhenfeng168/p/6919465.html
python基础:zip和dict详解相关推荐
- 【Python基础】reduce函数详解
转载请注明出处:[Python基础]reduce函数详解 reduce函数原本在python2中也是个内置函数,不过在python3中被移到functools模块中. reduce函数先从列表(或序列 ...
- Python基础语法day02字符串详解和列表
今天是python基础语法入门第二天,大概总共会有四天左右.四天后就是对于python的numpy库的详细文章.那话不多说,我们开始. 目录 字符串详解 字符串独有功能 检测头尾字符 判断输入结果是否 ...
- pythondict(zip())_python基础:zip和dict详解
一.zip函数:接受任意多个(包括0个和1个)序列作为参数,返回一个tuple列表. 1.示例1: x = [1, 2, 3] y = [4, 5, 6] z = [7, 8, 9] xyz = zi ...
- Python基础教程:括号()[]{}详解
Python主要有三种数据类型:字典.列表.元组.其分别由花括号,中括号,小括号表示. 如: 字典:dic={'a':12,'b':34} 列表:list=[1,2,3,4] 元组:tup=(1,2, ...
- 刻意练习:Python基础 -- Task13. datetime模块详解
datetime模块 datetime 是 Python 中处理日期的标准模块,它提供了 4 种对日期和时间进行处理的类:datetime.date.time 和 timedelta. datetim ...
- Python基础——模块和包详解以及pip操作模块和包的指令
随着项目越来越大,所有代码都放在一个文件中,已经不能满足我们的需求了.这时候就要将代码进行整理了,模块和包的出现就是为了解决这个问题的.模块可以将一些相关联的代码组合在一个py文件中,包可以将一些相关 ...
- python基础代码库-CNN详解-基于python基础库实现的简单CNN
CNN,即卷积神经网络,主要用于图像识别,分类.由输入层,卷积层,池化层,全连接层(Affline层),Softmax层叠加而成.卷积神经网络中还有一个非常重要的结构:过滤器,它作用于层与层之间(卷积 ...
- 【Python基础】2万字-详解Python基础函数,包教包会
- python中uniform_Python基础之uniform()的详解
描述 uniform() 方法将随机生成下一个实数,它在[x,y]范围内. 语法 以下是 uniform() 方法的语法:import random random.uniform(x, y) 注意:u ...
最新文章
- 【 C 】关于相邻字符串常量自动合并的标准(新旧标准)(新旧风格)(陷阱)
- Linux 系统调用(一)
- python创建字典型数据_Python数据类型之字典dict
- Matlab中下标,斜体,及希腊字母的使用方法
- Cookie,Session的区别
- 【筛素数】P1579 哥德巴赫猜想(升级版)
- 做网页前端遇到的一些问题
- vtkBorderWidget设置窗口位置的问题
- Mircosoft 正式把Windows Mobile改名为Windows Phone,你会因此而购买Windows Phone吗?
- Codeforces 55D Beautiful Number (数位统计)
- net user 用户名 密码 /add 建立用户
- 剑指offer(刷题61-65)--c++,Python版本
- linux杀死进程删除文件,linux 常用到的命令 删除 移动 复制 查询端口 杀死进程 查询进程...
- Array flat
- CSS相关知识点:6种清除浮动和BFC
- 水晶报表繁体转简体心得:之一 RPT文件篇
- windows内网的情况下如何访问外网
- 跟李沐学AI:实用机器学习 | 第一章
- 【转】程序员面试揭秘之程序员靠什么途径去美国工作?
- 计算机输入输出接口形式,输入输出接口-微计算机原理-电子发烧友网站