08 序列--元组&字典&集合

1. 元组简介

元组简介
• 元组表现形式/类型为tuple
• 元组是一个不可变序列(一般当我们希望数据不改变时,我们使用元组,其他情况下基本都用列表)
• 使用()创建元素
• 元组创建后,若括号()里面什么元素都没有,则为空元组。
若不是空元组至少有一个 逗号(,) 当元组不是空元组时括号可以省略
元组不能通过索引修改变量

tupl = (1,2,3,4)
tupl[2] = 10
print(tupl)
#输出结果会报错

• 元组解包指将元组当中的每一个元素都赋值给一个变量

tupl =(1,2,3)
 a,b,c = tupl
 print(a,b,c)
 #输出结果为 a=1 b=2 c=3 

2. 可变对象

Python中,数值类型(int和float)、字符串str、元组tuple都是不可变类型。而列表list、字典dict、集合set是可变类型
可变对象指的就是我们可以对对象里面的value进行改变
对象三要素:id(标识),type(类型),value(值)

a = [1,2,3]
a[0] = 10(只改变了对象的值)
----------
a = [4,5,6](给a重新赋值,此时a的对象(包括idtype,value)

注:程序结束后,这些变量的内存都会被清空释放。

改对象的值,会影响所有改变该对象的变量的值。
a = [1,2,3]
b = a
b[0] = 10
print('a',a,id(a))
print('b',b,id(b))
a = [10,2,3]
b = [10,2,3]
此时,a与b的id相同
-----------------
位一个变量重新赋值,不影响其他变量:
a = [1,2,3]
b = a
b = [10,2,3]
print('a',a,id(a))
print('b',b,id(b))
a = [1,2,3]
b = [10,2,3]
此时,a与b的id不相同

3. 字典简介

子序列:
my_tuple = (1,2,3,[ 5,6,7,8,9 ]),其中[5,6,7,8,9]为子序列
my_tuple =([1,2,3],[ 5,6,7,8,9 ]),其中[1,2,3]与[ 5,6,7,8,9 ]称为双子序列

3.1 字典的基本介绍

• 字典属于一种新的数据结构称为映射(mapping)
• 字典的作用和列表类似,都是用来存储对象的容器
• 列表存储数据的性能好,但是查询数据的性能差,字典正好与之相反
• 在字典中每一个元素都有唯一的名字key,通过这个唯一的名字key可以快速找到指定的元素value
• 字典我们也称之为键值对(key-value)结构
• 每个字典中都可以有多个键值对,而每一个键值对我们称其为一项(item)
• 创建一个有数据的字典 语法 {key1:value1,key2:value2…},然后通过一个key来寻找
字典的值可以是任意对象 字典的键可以是任意的不可变对象(int str bool tuple…)
• 字典的键是不能重复的,如果出现重复的后面的会替换前面的

3.2 字典的使用

• dict()函数来创建字典

in 查找字典中是否存在对应的键值
not in 查找字典中是否不存在对应的键值
len( )获取字典键值对的个数

d = dict (name='ben',age=7)
d['name'] = 'kobe'   #替换掉name对应的value
d['weight'] = 120    #key(weight)不存在字典d中,
                     #因此向字典中添加新的key-value
print(d)
输出:{'name': 'kobe', 'age': 7, 'weight': 120}

------------------------

d = dict (name='ben',age=7)
d['name'] = 'kobe'
d['weight'] = 120
r = d.setdefault('high',170)
print(r)
print(d)
170
{'name': 'kobe', 'age': 7, 'weight': 120, 'high': 170}

d.setdefault(key,default):
若key已经存在到字典当中,则返回key的值 不会对字典做任何操作
若key不存在,则向字典中添加这个Key 并设置value

• get(key,[default]) 根据键来获取字典的值。第二个参数可以指定一个默认值,当获取不到值的时候会返回默认值,default = None

d = dict (name='ben',age=7)
print(d.get('gender','have not'))
输出:have not

• update() 将其他字典的key-value添加到当前的字典当中,如果有重复的key 则后面的会替换到当前的

d = {'a':1,'b':2,'c':3}
d2 = {'d':4,'e':5,'f':6,'a':7}
d.update(d2)
print(d)
输出:{'a': 7, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6}

• del 删除字典中的key-value

d = {'a':1,'b':2,'c':3'd':4,'e':5,'f':6}
del d['a']
del d['f'] 
print(d)
输出为{'b': 2, 'c': 3, 'd': 4, 'e': 5}

• popitem() 删除字典最后的一个key-value 这个方法是有返回值的。删除之后它会将删除的key-value作为返回值返回

d = {'a':1,'b':2,'c':3,'d':4,'e':5,'f':6,}
r = d.popitem()
print(r)
print(d)
输出
('f', 6)
{'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}

• pop(key,[default]) 根据key删除自定中的value。第二个参数可以指定一个默认值,当获取不到值的时候会返回默认值

d = {'a':1,'b':2,'c':3,'d':4,'e':5,'f':6,}
r = d.pop('c')   #‘c’存在于字典中
print(r)
print(d)
输出
3
{'a': 1, 'b': 2, 'd': 4, 'e': 5, 'f': 6}

d = {'a':1,'b':2,'c':3,'d':4,'e':5,'f':6,}
r = d.pop('g','have not')   #‘g’不存在于字典中
print(r)
print(d)
输出
have not
{'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6}

• copye()

d = {'a':1,'b':2,'c':3}
# 复制后的对象和原对象是独立,修改一个不会影响另一个
d2 = d.copy()
d['b'] = 50
d['a'] =30
print('d =',d,id(d))
print('d2 =',d2,id(d2))

copy() 方法用来对字典进行浅复制

注:潜复制只会复制字典本身,如果字典中还有个字典(或可变对象)是不会进行复制的(即复制后字典中的可变对象还是和源字典中的可变对象是同一对象)

d = {'a':{'name':'ben','age':7},'b':2,'c':3}
d2 = d.copy()
d2['a']['name']='kobe'
print(d,id(d))
print(d2,id(d2))
输出
{'a': {'name': 'kobe', 'age': 7}, 'b': 2, 'c': 3} 19845456
{'a': {'name': 'kobe', 'age': 7}, 'b': 2, 'c': 3} 19845888
此时字典中的字典进行的就是浅复制
----------------------------------

d = {'a':{'name':'ben','age':7},'b':2,'c':3}
d2 = d.copy()
d2['b']=999
print(d,id(d))
print(d2,id(d2))
输出
{'a': {'name': 'kobe', 'age': 7}, 'b': 2, 'c': 3} 19845456
{'a': {'name': 'kobe', 'age': 7}, 'b': 999, 'c': 3} 19845888
此时修改的不是字典中的可变对象,所以修改其中一个对象的值并不影响另外一个对象的值

4.遍历字典

我们主要可以通过3种⽅式对字典进行遍历

  • keys() 该方法返回字典所有的key
  • values() 该方法返回一个序列 序列中保存有字典的值
  • items() 该方法会返回字典中所有的项 它返回一个序列,序列中包含有双值序列,双值分别是字典中的key和value
第一种
d = {'a':'ben','b':'黄子华','c':'陈赫','d':'小猪'}
print(d.keys())
for k in d.keys():
    print(d[k])

第二种
d = {'a':'ben','b':'黄子华','c':'陈赫','d':'小猪'}
print(d.values())
for v in d.values():
   print(v)

第三种
d = {'a':'ben','b':'黄子华','c':'陈赫','d':'小猪'}
print(d.items())
for k,v in d.items():
    print(k,v,)
    

5. 集合

5.1 集合简介

  • 集合的表现形式为 set
  • 集合与列表的不同点
    • 集合存储的对象是不可变对象
    • 集合里面的元素是无序的
    • 集合不能有重复的元素,若重复出现,重复的元素只显示一次
  • 集合通过{ }创建
  • 可通过set()函数使序列或者字典转换成集合
s = {[1,2,3,4,5,6]}
print(s,type(s))  #TypeError: unhashable type: 'list'
使用set()函数修改:
s = set([1,2,3,4,5,6])
print(s,type(s))  #{1, 2, 3, 4, 5, 6} <class 'set'>

s = set('python')
print(s,type(s))
s = set({'a':1,'b':2}) # 使用set()函数将字典转换为集合时,只包含字典的keys(键)
print(s,type(s))

注意:set()只能接受一个序列参数
s = set([1,2,3],[4,5,6])
print(s)    #TypeError: set expected at most 1 arguments, got 2

5.2 集合的方法

  • len( ) ,获取集合中元素的数量
  • add( ),向集合中添加元素
  • update( ),将一个集合中的元素添加到另一个集合当中
  • pop( ),随机删除集合中的一个元素,一般是删除最后一个元素,返回删除元素的值
  • remove( ), 删除集合中指定的元素,无返回值
  • clear() 清空集合

5.3 集合的运算

& 交集运算
| 并集运算
- 差集运算
^ 亦或集
<= 检查一个集合是否是另一个集合的子集
< 检查一个集合是否是另一个集合的真子集
>=检查一个集合是否是另一个集合的超集
>检查一个集合是否是另一个集合的真超集

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值