文章目录
元组
访问元组
- Python 的元组与列表类似,不同之处在于元组的元素不能修改。元组使用小括号 ( ),列表使用方括号 [ ]。元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可。
- 元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当作运算符使用:
tup4 = ()#创建空元组
tup1 = (1,)
tup2 = (2)
tup3 = "a", "b", "c", "d" # 不需要括号也可以#括号可以省略
print(type(tup3))
print(type(tup2))
print(type(tup1))
运行结果:
D:\shihaoqing\venv\Scripts\python.exe D:/shihaoqing/上课资料/元组.py
<class 'tuple'>
<class 'int'> #不加逗号为整型
<class 'tuple'> #加逗号为元组
Process finished with exit code 0
- 元组与字符串类似,下标索引从 0 开始,可以进行截取,组合等。
tup3 = "a", "b", "c", "d"
print(tup3[0])
print(tup3[0:2])
运行结果:
D:\shihaoqing\venv\Scripts\python.exe D:/shihaoqing/上课资料/元组.py
a
('a', 'b')
Process finished with exit code 0
修改元组
- 元组中的元素值是不允许修改的,但我们可以对元组进行连接组合,如下实例:
tup1 = (12, 34.56)
tup2 = ('abc', 'xyz')
tup1[0] = 23 #这个操作是错误的列表中的元素值是不允许修改的运行结果中会报错
print(tup1)
结果:
D:\shihaoqing\venv\Scripts\python.exe D:/shihaoqing/上课资料/元组.py
Traceback (most recent call last):
File "D:/shihaoqing/上课资料/元组.py", line 12, in <module>
tup1[0] = 23
TypeError: 'tuple' object does not support item assignment
Process finished with exit code 1
tup1 = (12, 34.56)
tup2 = ('abc', 'xyz')
tup3 = tup1 + tup2
print (tup3)
D:\shihaoqing\venv\Scripts\python.exe D:/shihaoqing/上课资料/元组.py
(12, 34.56, 'abc', 'xyz')
Process finished with exit code 0
删除元组
- 元组中的元素值是不允许删除的,但我们可以使用del语句来删除整个元组,如下实例:
tup1 = (12, 34.56)
print(tup1)
del tup1
print(tup1)
(12, 34.56)
Traceback (most recent call last):
File "D:/shihaoqing/上课资料/元组.py", line 17, in <module>
print(tup1)
NameError: name 'tup1' is not defined
Process finished with exit code 1
元组运算符
元组内置函数
字典
- 字典是另一种可变容器模型,且可存储任意类型对象。
- 字典的每个键值 key=>value 对用冒号 : 分割,每个对之间用逗号(,)分割,整个字典包括在花括号 {} 中 ,格式如下所示:
d = {key1 : value1, key2 : value2, key3 : value3 }
- 键必须是唯一的,但值则不必。值可以取任何数据类型,但键必须是不可变的,如字符串,数字。
- 也可这样创建字典:
dict1 = { 'abc': 456 }
dict2 = { 'abc': 123, 98.6: 37 }
访问字典里的值
把相应的键放到花括号中:
dic1 = {'Name': 'Run', 'Age': 7, 'Class': 'First'}
print(dic1['Name'])
D:\shihaoqing\venv\Scripts\python.exe D:/shihaoqing/上课资料/元组.py
Run
如果用字典中没有的键访问会报错
修改字典
dic1['Name'] = 'quit'
print(dic1)
dic1['age'] = '12'
print(dic1)
结果输出:
dic1['Name'] = 'quit' #更新
print(dic1)
dic1['age'] = '12' #添加
print(dic1)
删除字典元素
dic1 = {'Name': 'Run', 'Age': 7, 'Class': 'First'}
del dic1['Name'] # 删除键 'Name'
dic1.clear() # 清空字典
del dic1 # 删除字典
字典键的特性
- 键必须不可变,所以可以用数字,字符串或元组充当,而用列表就不行。
- 不允许同一个键出现两次。创建时如果同一个键被赋值两次,后一个值会被记住。
字典内置函数&方法
dic1 = {'Name': 'Run', 'Age': 7, 'Class': 'First'}
print(len(dic1)) #len()计算字典元素个数,即键的总数。
print(str(dic1)) #str(dict)输出字典,以可打印的字符串表示。
print(type(dic1)) #type(variable)返回输入的变量类型,如果变量是字典就返回字典类型
运行结果:
3
{'Name': 'Run', 'Age': 7, 'Class': 'First'}
<class 'dict'>
-
1 radiansdict.clear() 删除字典内所有元素
-
2 radiansdict.copy() 返回一个字典的浅复制
-
3 radiansdict.fromkeys() 创建一个新字典,以序列seq中元素做字典的键,val为字典所有键对应的初始值
-
4 radiansdict.get(key, default=None) 返回指定键的值,如果键不在字典中返回 default设置的默认值
-
5 key in dict 如果键在字典dict里返回true,否则返回false
-
6 radiansdict.items() 以列表返回可遍历的(键, 值) 元组数组
-
7 radiansdict.keys()返回一个迭代器,可以使用 list() 来转换为列表
-
8 radiansdict.setdefault(key,default=None) 和get()类似,
但如果键不存在于字典中,将会添加键并将值设为default -
9 radiansdict.update(dict2) 把字典dict2的键/值对更新到dict里
-
10 radiansdict.values() 返回一个迭代器,可以使用 list() 来转换为列表
-
1 pop(key[,default]) 删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。否则,返回default值。
-
12 popitem() 随机返回并删除字典中的最后一对键和值。
深拷贝和浅拷贝
- 浅拷贝(copy):拷贝父对象,不会拷贝对象的内部的子对象。
- 深拷贝(deepcopy): copy 模块的 deepcopy 方法,完全拷贝了父对象及其子对象。
import copy
a = [1, 2, 3, 4, ['a', 'b']] #原始对象
b = a #赋值,传对象的引用
c = copy.copy(a) #对象拷贝,浅拷贝只拷贝父对象
d = copy.deepcopy(a) #对象拷贝,深拷贝子父都拷贝
a.append(0) #修改对象a
a[4].append('c') #修改对象a中的['a', 'b']数组对象
print( 'a = ', a )
print( 'b = ', b )
print( 'c = ', c )
print( 'd = ', d )
'a = ', [1, 2, 3, 4, ['a', 'b', 'c'], 0])
'b = ', [1, 2, 3, 4, ['a', 'b', 'c'], 0])
'c = ', [1, 2, 3, 4, ['a', 'b', 'c']])
'd = ', [1, 2, 3, 4, ['a', 'b']])
集合
- 集合(set)是一个无序的不重复元素序列。
- 可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { }是用来创建一个空字典。
set(key)
或
set1 = {'mum'}
a = set('1234523') #集合有去重的功能
print(a)
运行结果:
{'5', '3', '4', '2', '1'}
集合的运算
a = {1, 2, 3, 4, 5}
b = {1, 2, 7, 8, 9}
print(a - b) # 集合a中包含而集合b中不包含的元素
print(a | b) # 集合a或b中包含的所有元素
print(a & b) # 集合a和b中都包含了的元素
print(a ^ b) # 不同时包含于a和b的元素
输出结果:
{3, 4, 5}
{1, 2, 3, 4, 5, 7, 8, 9}
{1, 2}
{3, 4, 5, 7, 8, 9}
集合的基本操作
1.添加元素
#add()
a = {1, 2, 3, 4, 5}
a.add(7) #将元素 7 添加到集合 a 中,如果元素已存在,则不进行任何操作。
print(a)
结果:
{1, 2, 3, 4, 5, 7}
# #update() #这个方法也可以添加元素,且参数可以是列表,元组,字典等
a = {1, 2, 3, 4, 5}
a.update([6, 7, 8, 9])
print(a)
a.update((10, 11))
print(a)
a.update({12, 13})
print(a)
结果:
{1, 2, 3, 4, 5, 6, 7, 8, 9}
{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11}
{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}
2.删除元素
1.remove()
#s.remove(x)将元素 x 从集合 s 中移除,如果元素不存在,则会发生错误
a = {1, 2, 3, 4, 5}
a.remove(1)
print(a)
a.remove(7)
print(a)
结果:
{2, 3, 4, 5}
Traceback (most recent call last):
File "D:/shihaoqing/上课资料/元组.py", line 58, in <module>
a.remove(7)
KeyError: 7
2.discard()
# s.discard(x) #将元素 x 从集合 s 中移除,如果元素不存在也不会报错
a = {1, 2, 3, 4, 5}
a.discard(1)
print(a)
a.discard(7)
print(a)
结果:
{2, 3, 4, 5}
{2, 3, 4, 5}
3.pop()
#pop()随机删除集合中的一个元素 #set 集合的 pop 方法会对集合进行无序的排列,然后将这个无序排列集合的左面第一个元素进行删除。
a = {'num', 'set', 'dic', 'str', 'int'}
a.pop()
print(a)
多次运行的结果:
{'set', 'dic', 'num', 'int'}
{'int', 'set', 'num', 'dic'}
{'int', 'set', 'str', 'num'}
3.计算集合元素个数
#len()
a = {'num', 'set', 'dic', 'str', 'int'}
print(len(a))
运行结果:
5
4.清空集合
#clear()
a = {'num', 'set', 'dic', 'str', 'int'}
a.clear()
print(a)
输出结果:
set()
5.判断元素是否在集合中存在
#x in s #判断元素 x 是否在集合 s 中,存在返回 True,不存在返回 False。
a = {'num', 'set', 'dic', 'str', 'int'}
print('num' in a)
print('age' in a)
结果:
True
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() 给集合添加元素
作业
#找到python1python2python3
a = {'name': '123', 'data': {'result': [{'src': 'python1'}, {'src': 'python2'}, {'src': 'pytnon3'}]}}
for i in a['data']['result']:
print(i['src'])
python1
python2
pytnon3
#有如下列表值[11, 22, 33, 44, 55, 66, 77, 88, 99, 90}]将所有大于66的值保存至字典的第一个key的值中,将小于66的值保存至第二个key值中。
a = [11, 22, 33, 44, 55, 66, 77, 88, 99, 90]
b = []
c = []
dic = {}
for i in a:
if i < 66:
b.append(i)
elif i > 66:
c.append(i)
print(b)
print(c)
dic.setdefault('key1', b)
dic.setdefault('key2', c)
print(dic)
[11, 22, 33, 44, 55]
[77, 88, 99, 90]
{'key1': [11, 22, 33, 44, 55], 'key2': [77, 88, 99, 90]}