07-元组&字典&集合

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…)
      • 字典的键是不能重复的,如果出现重复的后面的会替换前面的
#!/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
#!/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() 清空集合
#!/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
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值