07-元组&字典&集合
- 1、元组简介
- 元组表现形式tuple
- 元组是一个不可变序列(一般当我们希望数据不改变时,我们使用元组,其他情况下基本都用列表)
- 使用()创建元素
- 元组不是空元组至少有一个 逗号(,) 当元组不是空元组时括号可以省略
- 元组解包指将元组当中的每一个元素都赋值给一个变量
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2020/9/1 0001 9:51
# @Author : Oliver
#创建元组
my=(1,2,3,4,5)
print(my,type(my))
#通过下标取值
print(my[4])
#以下的方式也是创建元组
my=10,
print(my,type(my))
my=1,2,3,4
print(my,type(my))
#元组的解包
#解包指的是将元组的元素都赋值给一个变量
#有多少的元素就应该有多少的变量,要对应上,不然会报错
a,b,c,d=my
print('a=',a)
print('b=',b)
print('c=',c)
print('d=',d)
#那么元组中很多很多的元素怎么办呢
a,b,*c=my
print('a=',a)
print('b=',b)
#多余的元素就组成了一个列表的形式往*变量中展示出来
print('c=',c)
a,*b,c=my
print('a=',a)
print('b=',b)
print('c=',c)
结果显示:
(1, 2, 3, 4, 5) <class 'tuple'>
5
(10,) <class 'tuple'>
(1, 2, 3, 4) <class 'tuple'>
a= 1
b= 2
c= 3
d= 4
a= 1
b= 2
c= [3, 4]
a= 1
b= [2, 3]
c= 4
- 2、字典简介
- 2.1、字典的基本介绍
- 字典属于一种新的数据结构称为映射(mapping)
- 字典的作用和列表类似,都是用来存储对象的容器
- 列表存储数据的性能好,但是查询数据的性能差,字典正好与之相反
- 在字典中每一个元素都有唯一的名字,通过这个唯一的名字可以找到指定的元素
- 这个唯一的名字我们称之为key 通过key可以快速查询value 也可以称之为值
- 字典我们也称之为键值对(key-value)结构
- 每个字典中都可以有多个键值对,而每一个键值对我们称其为一项(item)
- 创建一个有数据的字典 语法 {key:value}
- 字典的值可以是任意对象 字典的键可以是任意的不可变对象(int str bool tuple…)
- 字典的键是不能重复的,如果出现重复的后面的会替换前面的
- 2.1、字典的基本介绍
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2020/8/31 0031 21:02
# @Author : Oliver
#字典 dict
#字典的键是不能重复的,如果重复的话后面的会覆盖前面的
d={'name':'葫芦娃','age':7,'gender':'男','name':'葫芦娃小金刚'}
print(d,type(d))
#根据键获取值
print(d['name'],d['age'],d['gender'])
结果显示:
{'name': '葫芦娃小金刚', 'age': 7, 'gender': '男'} <class 'dict'>
葫芦娃小金刚 7 男
- 2.2、字典的使用
- dict()函数来创建字典
- get(key[,default]) 根据键来获取字典的值。第二个参数可以指定一个默认值,当获取不到值的时候会返回默认值
- update() 将其他字典的key-value添加到当前的字典当中
- del 删除字典中的key-value
- popitem() 删除字典最后的一个key-value 这个方法是有返回值的。删除之后它会将删除的key-value作为返回值返回
- pop(key[,default]) 根据key删除自定中的value。第二个参数可以指定一个默认值,当获取不到值的时候会返回默认值
- clear()清空内容
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2020/8/31 0031 21:13
# @Author : Oliver
#使用dict()来创建字典
d=dict(name='葫芦娃',age=7,gender='男')
print(d,type(d))
#dict也可以将一个包含有双值子序列的序列转换为字典
#双值序列:序列当中有2个值[4,5],(1,2),'ab'
#子序列:如果序列当中的元素也是序列我们就成这个元素为子序列
s=dict([('name','葫芦娃'),('age',7)])
print(s,type(s))
#len()获取序列中键值对的个数
print(len(s))
#in检查字典中是否包含有指定的键
#not in .......
print('name' in s)
# get(key,default)通过get来获取字典当中的值
#没有key值就返回default的值
print(s.get('name','我也不知道'))
print(s.get('zzz','没有这个键'))
#可以修改,如果字典中没有key,那么先在字典中添加该key-value
d={'name':'葫芦娃','age':7,'gender':'男'}
d['name']='刚天下'
d['phone']='17858990800'
print(d)
#setdefault(key,default)可以向字典中添加key-value,
# 如果key已经存在在字典中,那么不会造成什么影响
#如果字典中的key值不存在,则向这个字典中添加key,并设置value
r=d.setdefault('name','蜘蛛')
print(r)
print(d)
r=d.setdefault('python','我喜欢')
print(r)
print(d)
#update()将其他的字典中的key-value添加到当前的字典中国
d={'a':1,'b':2,'c':3}
d1={'d':4,'e':5,'f':6,'a':7}
#d1添加到了d当中,如果有重复的key,后面的额会覆盖前面的
d.update(d1)
print(d)
print(d1)
#删除
#可以用del关键字来删除字典中的key-value
del d['a']
del d['b']
print(d)
#popitem()也是可以删除的,随机删除一个key-value,一般都会删除最后一个的
#删除之后的会将删除的key-value作为返回值返回
#返回的是一个元组,元组中有2个元素,第一个是删除的key,第二个是value
d.popitem()
print(d)
r=d.popitem()
print(d)
print(r)
#pop()根据key来删除字典中的key-value
r=d.pop('d')
print(r)
print(d)
r=d.pop('w','这个key不存在')
print(r)
#清空字典clear()
r=d.clear()
print(r)
print(d)
结果显示:
{'name': '葫芦娃', 'age': 7, 'gender': '男'} <class 'dict'>
{'name': '葫芦娃', 'age': 7} <class 'dict'>
2
True
葫芦娃
没有这个键
{'name': '刚天下', 'age': 7, 'gender': '男', 'phone': '17858990800'}
刚天下
{'name': '刚天下', 'age': 7, 'gender': '男', 'phone': '17858990800'}
我喜欢
{'name': '刚天下', 'age': 7, 'gender': '男', 'phone': '17858990800', 'python': '我喜欢'}
{'a': 7, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6}
{'d': 4, 'e': 5, 'f': 6, 'a': 7}
{'c': 3, 'd': 4, 'e': 5, 'f': 6}
{'c': 3, 'd': 4, 'e': 5}
{'c': 3, 'd': 4}
('e', 5)
4
{'c': 3}
这个key不存在
None
{}
- 2.3、copy()
- copy() 方法用来对字典进行浅复制
- 注意:浅复制只会复制字典本身,如果字典中还有个字典是不会进行复制的
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2020/8/31 0031 21:50
# @Author : Oliver
#copy()该方法用于对于字典进行浅复制
d={'a':1,'b':2,'c':3}
d1=d
d['b']=4
print('d=',d,id(d))
print('d1=',d1,id(d1))
#这样的不是浅复制,因为指向的是一个对象,要修改都是一起修改了
#copy()就是各自修改各自的
d1=d.copy()
d['b']=8
print('d=',d,id(d))
print('d1=',d1,id(d1))
#浅复制只会复制字典表面的一层,相当于字典当中包含字典,只会管理到外面的一层
d={'a':{'name':'黑猫警长'},'b':2,'c':3}
d1=d.copy()
print('d=',d,id(d))
print('d1=',d1,id(d1))
d1['a']['name']='圣斗士星矢'
print('d=',d,id(d))
print('d1=',d1,id(d1))
结果显示:
d= {'a': 1, 'b': 4, 'c': 3} 2353013151936
d1= {'a': 1, 'b': 4, 'c': 3} 2353013151936
d= {'a': 1, 'b': 8, 'c': 3} 2353013151936
d1= {'a': 1, 'b': 4, 'c': 3} 2353013152320
d= {'a': {'name': '黑猫警长'}, 'b': 2, 'c': 3} 2353013533120
d1= {'a': {'name': '黑猫警长'}, 'b': 2, 'c': 3} 2353013151936
d= {'a': {'name': '圣斗士星矢'}, 'b': 2, 'c': 3} 2353013533120
d1= {'a': {'name': '圣斗士星矢'}, 'b': 2, 'c': 3} 2353013151936
Process finished with exit code 0
- 3、遍历字典
- 我们主要可以通过3种方式对字典进行遍历
- keys() 该方法返回字典所有的key
- values() 该方法返回一个序列 序列中保存有字典的值
- items() 该方法会返回字典中所有的项 它返回一个序列,序列中包含有双值子序列 双值分别是 字典中的key和value
- 我们主要可以通过3种方式对字典进行遍历
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2020/9/2 0002 20:01
# @Author : Oliver
#遍历字典
#keys() 该方法返回字典所有的key
d={'name':'葫芦娃','age':7,'gender':'男','name':'葫芦娃小金刚'}
print(d.keys())
for k in d.keys():
print(d[k])
#values() 该方法返回一个序列 序列中保存有字典的值
for v in d.values():
print(v)
#items() 该方法会返回字典中所有的项 它返回一个序列,序列中包含有双值子序列 双值分别是 字典中的key和value
print(d.items())
for i,j in d.items():
print(i,j)
结果显示:
dict_keys(['name', 'age', 'gender'])
葫芦娃小金刚
7
男
葫芦娃小金刚
7
男
dict_items([('name', '葫芦娃小金刚'), ('age', 7), ('gender', '男')])
name 葫芦娃小金刚
age 7
gender 男
Process finished with exit code 0
- 4、集合
- 4.1、集合简介
- 集合表现形式set 集合和列表非常相似
- 不同点
- 集合只能存储不可变对象
- 集合中存储的对象是无序的
- 集合不能出现重复元素
- 使用{}来创建集合
- 可以通过set()来将序列和字典转换成集合
- len() 使用len()来获取集合中元素的数量
- add()像集合中添加元素
- update()将一个集合中的元素添加到另一个集合当中
- pop()随机删除集合中的一个元素一般是删除最后一个元素
- remove() 删除集合中指定的元素
- clear() 清空集合
- 4.1、集合简介
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2020/9/2 0002 20:07
# @Author : Oliver
#集合和列表非常的相似
#不同点
# 集合只能存储不可变对象
# 集合中存储的对象是无序的(不是按照元素插入的顺序来保存的)
# 集合不能出现重复元素
s={100,10,1,2,3,4,1,2,3,4}
print(s,type(s))
#s={}其实是空字典,而不是空集合
s={}
print(s,type(s))
#创建空集合使用的是set(),里面可传入的一个参数是可迭代的对象
s=set()
print(s,type(s))
#列表是可迭代的对象,那么可以将列表转换为集合
s=set([1,2,3,4,5])
print(s,type(s))
s=set('hello')
print(s,type(s))
#set不支持索引的,无法通过下标进行查询的,因为他本身就是没有顺序的,其实想通过下标也是没有意义的
#实在想找的话,进行list()转换
print(list(s)[0])
#add添加元素
s.add(4)
#update()将一个集合中的元素添加到另一个集合当中
s=set([1,2,3,4])
s2=set('hello')
s.update(s2)
print(s)
print(s2)
#pop()随机删除集合中的一个元素一般是删除最后一个元素
r=s.pop()
print(r)
print(s)
#remove() 删除集合中指定的元素
s.remove(2)
print(s)
# clear() 清空集合
s.clear()
print(s)
结果显示:
{1, 2, 3, 100, 4, 10} <class 'set'>
{} <class 'dict'>
set() <class 'set'>
{1, 2, 3, 4, 5} <class 'set'>
{'e', 'o', 'h', 'l'} <class 'set'>
e
{1, 2, 3, 4, 'o', 'l', 'h', 'e'}
{'e', 'o', 'h', 'l'}
1
{2, 3, 4, 'o', 'l', 'h', 'e'}
{3, 4, 'o', 'l', 'h', 'e'}
set()
Process finished with exit code 0
- 4.2、集合的运算
- & 交集运算
- | 并集运算
- - 差集运算
- ^ 亦或集
- <= 检查一个集合是否是另一个集合的子集
- < 检查一个集合是否是另一个集合的真子集
- >=检查一个集合是否是另一个集合的超集
- >检查一个集合是否是另一个集合的真超集
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2020/9/2 0002 20:28
# @Author : Oliver
# & 交集运算
# | 并集运算
# - 差集运算
# ^ 亦或集
# <= 检查一个集合是否是另一个集合的子集
# < 检查一个集合是否是另一个集合的真子集
# >=检查一个集合是否是另一个集合的超集
# >检查一个集合是否是另一个集合的真超集
s={1,2,3,4,5}
s2={3,4,5,6,7}
# & 交集运算
print(s&s2)
# | 并集运算
print(s|s2)
# - 差集运算
print(s-s2)
print(s2-s)
# ^ 异或集(彼此不相交的部分){1, 2, 6, 7}
print(s^s2)
# <= 检查一个集合是否是另一个集合的子集
print(s<=s2)
# < 检查一个集合是否是另一个集合的真子集
print(s<s2)
# >=检查一个集合是否是另一个集合的超集
a={1,2,3,4,5}
a1={1,2,3,4,5}
print(a1>=a)
# >检查一个集合是否是另一个集合的真超集
print(a1>a)
结果显示:
{3, 4, 5}
{1, 2, 3, 4, 5, 6, 7}
{1, 2}
{6, 7}
{1, 2, 6, 7}
False
False
True
False
Process finished with exit code 0
- 课程作业:
- 1.a = {“name”:“123”,“data”:{“result”:[{“src”:“python1”},{“src”:“python2”},{“src”:“python3”}]}} 找到python1/python2/python3
- 2.有如下值集合[11,22,33,44,55,66,77,88,99,90], 将所有大于66的值保存至字典的第一个key中,将小于66值保存至第二个key的值中。
在这里插入代码片
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2020/8/31 0031 22:17
# @Author : Oliver
# a = {"name":"123","data":{"result":[{"src":"python1"},{"src":"python2"},{"src":"python3"}]}}
# 找到python1/python2/python3
# 分析:a为字典,两个键值对,其中第二个键值对中的值为只有一个键值对的字典,且这个字典中的值为一个包含三个最内层字典的列表
a = {"name":"123","data":{"result":[{"src":"python1"},{"src":"python2"},{"src":"python3"}]}}
my_find = []
for num in range(0,3):
my_find.append(a['data']['result'][num]['src'])
print(my_find) #['python1', 'python2', 'python3']
# 有如下值集合[11,22,33,44,55,66,77,88,99,90],
# 将所有大于66的值保存至字典的第一个key中,将小于66值保存至第二个key的值中。
li = [11,22,33,44,55,66,77,88,99,90]
person = {">66":[],"<=66":[]}
for i,j in enumerate(li,0) :
if int(j) > 66 :
person[">66"].append(j)
else :
person["<=66"].append(j)
print(person)
结果显示:
['python1', 'python2', 'python3']
{'>66': [77, 88, 99, 90], '<=66': [11, 22, 33, 44, 55, 66]}
Process finished with exit code 0