Python元组相关知识

Python元组相关知识

1.  元组简介

1.1 元组基本介绍

  • Python 的元组与列表类似,不同之处在于元组的元素不能修改。
  • 元组表现形式tuple。
  • 元组是⼀个不可变序列(⼀般当我们希望数据不改变时,我们使⽤元组,其他情况下基本都⽤列表。
  • 元组使用小括号,列表使用方括号。元组不是空元组⾄少有⼀个 逗号(,) 当元组不是空元组时括号可以省略。
  • 元组解包指将元组当中的每⼀个元素都赋值给⼀个变量。
tup1 = ('python', 'liuyu', 1984, 99.88)
tup2 = (1, 2, 3, 4, 5 )
tup3 = "a", "b", "c", "d"   #  不需要括号也可以
print(type(tup1)) # <class 'tuple'>
print(type(tup2)) # <class 'tuple'>
print(type(tup3)) # <class 'tuple'>
  • 元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当作运算符使用:
tup1 = (50)
print(type(tup1)) # <class 'int'>
tup2 = (50,)
print(type(tup2)) # <class 'tuple'>

1.2 访问元组

元组可以使用下标索引来访问元组中的值,如下实例:

tup1 = ('python', 'liuyu', 1984, 99.88)
tup2 = (1,2,3,4,5)
print(tup1[0]) # python
print(tup1[1:3]) # ('liuyu', 1984)
# tup1[0] = 'Python'
# print(tup1) # TypeError: 'tuple' object does not support item assignment  修改元组元素操作是非法的。
tup3 = tup1 + tup2
print(tup3) # ('python', 'liuyu', 1984, 99.88, 1, 2, 3, 4, 5)

1.3 删除元组

元组中的元素值是不允许删除的,但我们可以使用del语句来删除整个元组,如下实例:

tup1 = ('python', 'liuyu', 1984, 99.88)
# tup1.pop() # AttributeError: 'tuple' object has no attribute 'pop'
# tup1.remove() # AttributeError: 'tuple' object has no attribute 'remove' 元组元素值是不允许删除的
del tup1
print(tup1) # NameError: name 'tup1' is not defined 可以通过del进行删除

1.4 元组运算符

与字符串一样,元组之间可以使用 + 号和 * 号进行运算。这就意味着他们可以组合和复制,运算后会生成一个新的元组。

Python 表达式结果描述
len((1, 2, 3))3计算元素个数
(1, 2, 3) + (4, 5, 6)(1, 2, 3, 4, 5, 6)连接
(‘Hi!’,) * 4(‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’)复制
3 in (1, 2, 3)True元素是否存在
for x in (1, 2, 3): print (x,)1 2 3迭代

1.5 元组索引,截取

因为元组也是一个序列,所以我们可以访问元组中的指定位置的元素,也可以截取索引中的一段元素,如下所示:

L = ('Google', 'Taobao', 'Runoob')
print(L[0]) # Google
print(L[-1]) # Runoob
print(L[0:2]) # ('Google', 'Taobao')
Python 表达式结果描述
L[2]‘Runoob’读取第三个元素
L[-2]‘Taobao’反向读取,读取倒数第二个元素
L[1:](‘Taobao’, ‘Runoob’)截取元素,从第二个开始后的所有元素。

1.6 元组内置函数

Python元组包含了以下内置函数

序号方法及描述实例
1len(tuple)
计算元组元素个数。
>>> tuple1 = (‘Google’, ‘Runoob’, ‘Taobao’)

len(tuple1)
3

|
| 2 | max(tuple)
返回元组中元素最大值。 | >>> tuple2 = (‘5’, ‘4’, ‘8’)

max(tuple2)
‘8’

|
| 3 | min(tuple)
返回元组中元素最小值。 | >>> tuple2 = (‘5’, ‘4’, ‘8’)

min(tuple2)
‘4’

|
| 4 | tuple(iterable)
将可迭代系列转换为元组。 | >>> list1= [‘Google’, ‘Taobao’, ‘Runoob’, ‘Baidu’]

tuple1=tuple(list1)
tuple1
(‘Google’, ‘Taobao’, ‘Runoob’, ‘Baidu’) |

1.7 关于元组是不可变的

所谓元组的不可变指的是元组所指向的内存中的内容不可变。

L = ('Google', 'Taobao', 'Runoob')
L[0]= 'liuyu' # TypeError: 'tuple' object does not support item assignment 元组中的元素值无法进行修改
print(L) 
list1 = ('Google', 'Taobao', 'Runoob')
print(id(list1)) # 2602683897896
list1 = (1,2,3,4,5)
print(id(list1)) # 2602680296200 内存地址发生了变化

2.  可变对象

Python中,数值类型(int和float)、字符串str、元组tuple都是不可变类型。⽽列表list、字典dict、集合set是可变类型
可变对象中都保存了三个数据

  • id(标识)
  • type(类型)
  • value(值)

可变对象指的就是我们可以对对象里面的value进行改变,可变对象中的值发生变化,但是内存地址不变。

list4 = ['python', 'liuyu', 1984, 99.88, 'Hello World', 'python', 'python']
print(id(list4)) # 3127787033800 内存地址未发生变化
list4.pop(1)
print(list4) # ['python', 1984, 99.88, 'Hello World', 'python', 'python'] 删除列表中的值,但是内存地址未发生变化
print(id(list4)) # 3127787033800 内存地址未发生变化
list4[5]='test'
print(list4) # ['python', 1984, 99.88, 'Hello World', 'python', 'test'] 改变列表中的值,但是内存地址未发生变化
print(id(list4)) # 3127787033800 内存地址未发生变化
list4.append('好玩的')
print(list4) # ['python', 1984, 99.88, 'Hello World', 'python', 'test', '好玩的'] 增加列表中的值,但是内存地址未发生变化
print(id(list4)) # 3127787033800 内存地址未发生变化

3.  字典简介

字典是另一种可变容器模型,且可存储任意类型对象。
字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号(**{})**中 ,格式如下所示:

d = {key1 : value1, key2 : value2 }
#键必须是唯一的,但值则不必。
#值可以取任何数据类型,但键必须是不可变的,如字符串,数字或元组。
#一个简单的字典实例:
dict = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'}
dict1 = { 'abc': 456 }
dict2 = { 'abc': 123, 98.6: 37 }
  • 字典属于⼀种新的数据结构称为映射(mapping)
  • 字典的作⽤和列表类似,都是⽤来存储对象的容器
  • 列表存储数据的性能好,但是查询数据的性能差,字典正好与之相反
  • 在字典中每⼀个元素都有唯⼀的名字,通过这个唯⼀的名字可以找到指定的元素。
  • 这个唯⼀的名字我们称之为key 通过key可以快速查询value 也可以称之为值
  • 字典我们也称之为键值对(key-value)结构
  • 每个字典中都可以有多个键值对,⽽每⼀个键值对我们称其为⼀项(item)
  • 创建⼀个有数据的字典 语法 {key:value}
  • 字典的值可以是任意对象 字典的键可以是任意的不可变对象(int str booltuple…)
  • 字典的键是不能重复的,如果出现重复的后⾯的会替换前⾯的

3.1 访问字典里的值

把相应的键放入到方括号中,如下实例:

dic = {'name': 'liuyu', 'age': 18, '体重': 69.5}
# 通过key返回value
print("name:", dic['name'])  # name: liuyu
print("age:", dic['age'])  # age: 18
print("体重:", dic['体重'])  # 体重: 69.5
# 如果字典中没有key,则报错
print("身高:", dic['身高']) # KeyError: '身高'

3.2 修改字典

向字典添加新内容的方法是增加新的键/值对,修改或删除已有键/值对如下实例:

dic = {'name': 'liuyu', 'age': 18, '体重': 69.5}
# 通过key返回value
dic['name'] = 'python'
dic['age'] = 30
dic['体重'] = 75 
print("dic内容:", dic)  # dic内容: {'name': 'python', 'age': 30, '体重': 75}

3.3 删除字典元素

能删单一的元素也能清空字典,清空只需一项操作。
显示删除一个字典用del命令,如下实例:

dic = {'name': 'liuyu', 'age': 18, '体重': 69.5}
del dic['name'] # 删除键 'name'  {'age': 18, '体重': 69.5}
print(dic)
dic.clear() # 清空字典 {}
print(dic)
del dic # 删除字典,NameError: name 'dic' is not defined
print(dic)

3.4 字典键的特性

字典值可以是任何的 python 对象,既可以是标准的对象,也可以是用户定义的,但键不行。
两个重要的点需要记住:
1)不允许同一个键出现两次。创建时如果同一个键被赋值两次,后一个值会被记住,如下实例:

dic = {'name': 'liuyu', 'age': 18, '体重': 69.5, 'name': 'python'}
print(dic) # {'name': 'python', 'age': 18, '体重': 69.5} name被赋值两次,最后打印的为最后一次的值

2)键必须不可变,所以可以用数字,字符串或元组充当,而用列表就不行,如下实例:

dic = {['name']: 'liuyu', 'age': 18, '体重': 69.5, 'name': 'python'}
print(dic) 
# Traceback (most recent call last):
#   File "C:/Users/MAC/PycharmProjects/phl/Moudule/test1.py", line 7, in <module>
#     dic = {['name']: 'liuyu', 'age': 18, '体重': 69.5, 'name': 'python'}
# TypeError: unhashable type: 'list'

3.5 字典内置函数&方法

Python字典包含了以下内置函数:

序号函数及描述实例
1len(dict)
计算字典元素个数,即键的总数。
>>> dict = {‘Name’: ‘Runoob’, ‘Age’: 7, ‘Class’: ‘First’}

len(dict)
3 |
| 2 | str(dict)
输出字典,以可打印的字符串表示。 | >>> dict = {‘Name’: ‘Runoob’, ‘Age’: 7, ‘Class’: ‘First’}

str(dict)
“{‘Name’: ‘Runoob’, ‘Class’: ‘First’, ‘Age’: 7}” |
| 3 | type(variable)
返回输入的变量类型,如果变量是字典就返回字典类型。 | >>> dict = {‘Name’: ‘Runoob’, ‘Age’: 7, ‘Class’: ‘First’}

type(dict)
<class ‘dict’> |

Python字典包含了以下内置方法:

序号函数及描述
1radiansdict.clear()
删除字典内所有元素
2radiansdict.copy()
返回一个字典的浅复制
3radiansdict.fromkeys()
创建一个新字典,以序列seq中元素做字典的键,val为字典所有键对应的初始值
4radiansdict.get(key, default=None)
返回指定键的值,如果值不在字典中返回default值
5key in dict
如果键在字典dict里返回true,否则返回false
6radiansdict.items()
以列表返回可遍历的(键, 值) 元组数组
7radiansdict.keys()
返回一个迭代器,可以使用 list() 来转换为列表
8radiansdict.setdefault(key, default=None)
和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default
9radiansdict.update(dict2)
把字典dict2的键/值对更新到dict里
10radiansdict.values()
返回一个迭代器,可以使用 list() 来转换为列表
11pop(key[,default])
删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值。
12popitem()
随机返回并删除字典中的最后一对键和值。
# 可以通过dict()函数来创建字典
a = dict(name='liuyu', age=18, 体重=69.5)  # {'name': 'liuyu', 'age': 18, '体重': 69.5}
print(a)

# 双值子序列
# 双值序列 序列中只有两个值,('x',1),'ab',[5,6]
# 子序列 如果序列中元素也是序列 那么我们就称这个元素为子序列 [(4,5),(6,7)]
b = dict([('name', 'liuyu'), ('age', 18), ('体重', 69.5)])
print(b, type(b))

# len()函数可以获取字典中键值对的个数
print(len(b))  # 3
# in 检查字典中是否包含指定的键
a = 'name' in b
print(a)  # True
# not in 检查字典中是否不包含指定的键
a = 'name' not in b
print(a) # False

# get(key[,default]) 该方法可以根据字典中的key来获取值
print(b.get('name')) # liuyu
# 如果获取字典中的键不存在 就会返回None
print(b.get('python')) # None
# 也可以指定一个默认值来作为第二个参数 这样获取不到值的时候回返回默认值
print(b.get('python','该值不存在')) # 该值不存在


# 修改字典 dict[key] = value
c = {'name': 'liuyu', 'age': 18, '体重': 69.5}
c['身高'] = 175 # 像字典中添加key-value
print(c) # {'name': 'liuyu', 'age': 18, '体重': 69.5, '身高': 175}
# dict.setdefault(key[,default]) 字典中添加key-value
# 如果key已经存在到字典当中,则返回key的值 不会对字典做任何操作
# 如果key不存在,则像字典中添加这个Key 并设置value
c.setdefault('name','liuyu')
print(c) # {'name': 'liuyu', 'age': 18, '体重': 69.5, '身高': 175} 不做任何操作
r = c.setdefault('python','liuyu')
print(r) # 新增python的这个key,同时设置值为:liuyu
print(c) # {'name': 'liuyu', 'age': 18, '体重': 69.5, '身高': 175, 'python': 'liuyu'}

# update()
# 将其他字典中的key-value添加到当前的字典当中
# 如果有重复的key 则后面的会替换到当前的
d = {'name': 'liuyu', 'age': 18, '体重': 69.5}
e = {'d':4,'e':5,'f':6,'a':7}
d.update(e)
print(d) # {'name': 'liuyu', 'age': 18, '体重': 69.5, 'd': 4, 'e': 5, 'f': 6, 'a': 7}

# popitem() 一般都会删除最后一个
# 删除之后它会将key-value作为返回值返回
# 返回的是一个元组 元组中有2个元素 第一个元素时key 第二个元素时value
d.popitem()
print(d) # {'name': 'liuyu', 'age': 18, '体重': 69.5, 'd': 4, 'e': 5, 'f': 6}
r = d.popitem()
print(d) # {'name': 'liuyu', 'age': 18, '体重': 69.5, 'd': 4, 'e': 5}
print(r) # ('f', 6)

# pop(key[,default]) 根据key删除字典中的key-value
# 会将删除的值返回
e = {'d':4,'e':5,'f':6,'a':7}
r = e.pop('d') # 4 降删除的值返回
d = e.pop('z','没有这个key值') # 没有这个key值
print(r)
print(d)

3.6 copy()

copy() ⽅法⽤来对字典进⾏潜复制
注意:潜复制只会复制字典本身,如果字典中还有个字典是不会进⾏复制的

# 采用正常的赋值语句
d = {'a':1,'b':2,'c':3}
d2 = d
print(d2) # {'a': 1, 'b': 2, 'c': 3}
d['b'] = 50
print(d2) # {'a': 1, 'b': 50, 'c': 3} d2受到了影响

# 复制后的对象和原对象是独立,修改一个不会影响另一个
e = {'a':1,'b':2,'c':3}
e2 = e.copy()
e['b'] =50
print('e =',e,id(e)) # e = {'a': 1, 'b': 50, 'c': 3} 2387552784032
print('e2 =',e2,id(e2)) # e2 = {'a': 1, 'b': 2, 'c': 3} 2387552817296 e2没有受到e改变的影响
# -------------------------------------------------
# 浅复制只会复制字典本身,如果字典中还有个字典是不会被复制的
# 浅复制会简单复制对象内部的值,如果值也是个可变对象,这个可变对象不会被复制
f = {'a':{'name':'蜘蛛侠','age':10},'b':2,'c':3}
f2 = f.copy()
f2['a']['name'] = 'liuyu'
print('f =',f,id(f))
print('f2 =',f2,id(f2))

4. 遍历字典


  • keys() 该方法返回的是字典所有的Key
  • values() 返回一个序列,该序列中保存有字典的值
  • items() 返回字典所有的项 它返回的是一个序列 序列包含的是双值子序列
  • 双值分别是 字典中的Key和value
d = {'a': 1, 'b': 2, 'c': 3}
print(d.keys())  # dict_keys(['a', 'b', 'c'])
print(d.values())  # dict_values([1, 2, 3])
for k in d.keys():
    print(k, end=' ')  # a b c 遍历所有key
for v in d.values():
    print(v, end=' ')  # 1 2 3  遍历所有values
for k, v in d.items():
    print(k, v, end=' ')  # a 1 b 2 c 3 遍历所有values

5. 集合

5.1 集合简介

集合(set)是一个无序的不重复元素序列。
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用** set()** 而不是 { },因为 { } 是用来创建一个空字典。
创建格式:

a = {'liuyu', 12345, 'python'}  # 返回<class 'set'>
print(type(a))
b = set('liuyu') # 返回<class 'set'>
print(type(b))
  • 集合表现形式set 集合和列表⾮常相似

不同点

  • 集合只能存储不可变对象
  • 集合中存储的对象是⽆序的
  • 集合不能出现重复元素
  • 使⽤{}来创建集合
  • 可以通过set()来将序列和字典转换成集合
  • len() 使⽤len()来获取集合中元素的数量
  • add()像集合中添加元素
  • update()将⼀个集合中的元素添加到另⼀个集合当中
  • pop()随机删除集合中的⼀个元素⼀般是删除最后⼀个元素
  • remove() 删除集合中指定的元素
  • clear() 清空集合

5.2 集合操作

5.2.1 添加元素

语法格式如下:

s.add( x )

将元素 x 添加到集合 s 中,如果元素已存在,则不进行任何操作。

a = set(('liuyu', 12345, 'python')) # 返回{12345, 'python', 'liuyu'}
print(a)
a.add('liuyu') # 返回:{12345, 'liuyu', 'python'} 如果元素已经存在,则不进行任何操作
print(a)
a.add('test')
print(a) # 返回:{12345, 'test', 'python', 'liuyu'} 新增test新元素

还有一个方法,也可以添加元素,且参数可以是列表,元组,字典等,语法格式如下:

a = set(('liuyu', 12345, 'python')) # 返回{12345, 'python', 'liuyu'}
a.update('test') # 更新字符串
print(a)
a.update({6,7,8}) # 更新字典
print(a)
a.update([22,'Hello']) # 更新列表
print(a)
a.update(set('movie')) # 更新元组
print(a)
# {'python', 'e', 's', 'liuyu', 't', 12345}
# # # {'python', 'e', 6, 7, 's', 8, 'liuyu', 't', 12345}
# # # {'python', 'e', 6, 7, 's', 8, 'Hello', 'liuyu', 't', 22, 12345}
# # # {'python', 'e', 6, 7, 's', 8, 'i', 'Hello', 'liuyu', 't', 'o', 'm', 22, 12345, 'v'}

5.2.2 移除元素

语法格式如下:

# s.remove( x ) 将元素 x 从集合 s 中移除,如果元素不存在,则会发生错误。
# s.discard( x ) 此外还有一个方法也是移除集合中的元素,且如果元素不存在,不会发生错误。
# s.pop() 我们也可以设置随机删除集合中的一个元素
a = set(('liuyu', 12345, 'python')) # 返回{12345, 'python', 'liuyu'}
a.remove('liuyu') # 更新字符串
print(a) # {'python', 12345}
# a.remove('test')
# print(a)
# 没有元素则会发生报错
# Traceback (most recent call last):
#   File "C:/Users/MAC/PycharmProjects/phl/Moudule/test1.py", line 10, in <module>
#     a.remove('test')
# KeyError: 'test'
a.discard('python')
print(a) # {12345}
b = set(('宝马','奔驰','路虎','大众'))
b.pop()
print(b) # {'路虎', '宝马', '奔驰'}

5.2.3 计算集合元素个数

语法格式如下:

len(s)

计算集合元素个数示例:

a = set(('liuyu', 12345, 'python')) 
print(len(a)) # 返回:3
a.remove('liuyu') 
print(len(a)) # 返回:2

5.2.4 清空集合

语法格式如下:

s.clear()

示例:

a = set(('liuyu', 12345, 'python'))
print(len(a)) # 返回:3
a.clear()
print(len(a)) # 返回:0

5.2.5 判断元素是否在集合中存在

语法格式如下:

x in s

判断元素 x 是否在集合 s 中,存在返回 True,不存在返回 False。示例:

a = set(('liuyu', 12345, 'python'))
print('liuyu' in a) # 返回:True
print('test' in a) # 返回:False

集合内置方法完整列表

方法描述
add()为集合添加元素
clear()移除集合中的所有元素
copy()拷贝一个集合
difference()返回多个集合的差集
difference_update()移除集合中的元素,该元素在指定的集合也存在。
discard()删除集合中指定的元素
intersection()返回集合的交集
intersection_update()返回集合的交集。
isdisjoint()判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。
issubset()判断指定集合是否为该方法参数集合的子集。
issuperset()判断该方法的参数集合是否为指定集合的子集
pop()随机移除元素
remove()移除指定元素
symmetric_difference()返回两个集合中不重复的元素集合。
symmetric_difference_update()移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。
union()返回两个集合的并集
update()给集合添加元素

5.2 集合的运算

  • & 交集运算
  • | 并集运算
    • 差集运算
  • ^ 亦或集
  • <= 检查⼀个集合是否是另⼀个集合的⼦集
  • < 检查⼀个集合是否是另⼀个集合的真⼦集
  • =检查⼀个集合是否是另⼀个集合的超集

  • 检查⼀个集合是否是另⼀个集合的真超集

basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'}
print(basket)  # 这里演示的是去重功能{'orange', 'pear', 'banana', 'apple'}

# 下面展示两个集合间的运算.
a = set('abracadabra')
b = set('alacazam')
print(a)  # {'a', 'b', 'c', 'd', 'r'}
print(b)  # {'a', 'z', 'l', 'c', 'm'}
print(a - b)  # 集合a中包含而集合b中不包含的元素{'d', 'b', 'r'}
print(a | b)  # 集合a或b中包含的所有元素{'c', 'a', 'd', 'r', 'l', 'z', 'b', 'm'}
print(a & b)  # 集合a和b中都包含了的元素{'a', 'c'}
print(a ^ b)  # 不同时包含于a和b的元素{'z', 'm', 'b', 'r', 'l', 'd'}
print(a > b)  # False
print(a >= b)  # False
print(a < b)  # False
print(a <= b)  # False

6. 练习

a = {“name”:“123”,“data”:{“result”:[{“src”:“python1”},{“src”:“python2”},{“src”:“python3”}]}} 找到
python1/python2/python3

a = {"name": "123", "data": {"result": [{"src": "python1"}, {"src": "python2"}, {"src": "python3"}]}}  # 设置字典a
print(type(a))  # <class 'dict'> #查看a的类型
b = (a["data"])  # 通过key提取data的值赋予b
print(b, type(b))  # {'result': [{'src': 'python1'}, {'src': 'python2'}, {'src': 'python3'}]} <class 'dict'>  查看b的元素值和类型
c = b["result"]  # 再通过key提取result的值赋予c
print(c, type(
    c))  # [{'src': 'python1'}, {'src': 'python2'}, {'src': 'python3'}] <class 'list'> 查看c的元素值和类型,此刻c为多个字典组成的列表,那么开始遍历此列表,通过索引的方式切片得到每一个子字典
i = 0
for i in range(len(c)):  # i在c范围内进行循环
    d = c[i]  # 通过索引得到c中的每个子字典赋予d
    e = d['src']  # 针对d中字典key提取value
    print(e, end='/')  # python1/python2/python3/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值