三、Python容器:列表(list)/字典(dict)/元组(tuple)/集合(set)

1、列表(list)

1.1 什么是列表

是一个‘大容器’,可以存储N多个元素简单来说就是其他语言中的数组。是一种有序的容器,放入list中的元素,将会按照一定顺序排列。和变量的区别,变量只可以存储一个对象的引用

1.2 创建

① 列表需要使用中括号[],元素之间使用英文的逗号进行分割

② 创建方式一:使用中括号

③ 创建方式二:使用内置函数list()

④ 创建方式三:列表生成式。简称为:生成列表的公式。注意:‘表达列表元素的表达式’中通常包含自定义变量

# 创建方式一
lis1 = ['hello', 'world', 98]
# 创建方式二
lst2 = list(['hello', 'world', 98])
# 创建方式三
lst = [i*i for i in range(1,10)]
print(lst) # ==>[1, 4, 9, 16, 25, 36, 49, 64, 81]
1.3 特点

① 列表元素按顺序有序排列

② 索引映射唯一一个数据

③ 列表可以存储重复数据

④ 任意数据类型混存

⑤ 根据需要动态分配和回收内存

1.4 查询(获取列表中单个元素)

① 获取列表中制定元素的索引

# 获取索引
lis1 = ['hello', 'world', 98, 'hello', 8.6]
# 1、如查列表中存在N个相同元素,只返回相同元素中的第一个元素的索引
print(lis1.index('hello')) # ==>0
# 2、如果查询的元素在列表中不存在,则会抛出ValueError
print(lis1.index('python')) # ==>ValueError
# 3、还可以在指定的start和stop之间查找
print(lis1.index('hello', 1, 4)) # ==>3

② 获取列表中的单个元素

# 获取单个元素
lis1 = ['hello', 'world', 98, 'hello', 8.6]
# 1、正向索引从0到1
print(lis1[2]) # ==>98
# 2、逆向索引从-1开始
print(lis1[-2]) # ==>hello
# 3、指定索引不存在,抛出IndexError
print(lis1[10]) # ==>IndexError

③ 判断元素是否在列表中存在

lst = ['hello', 'world', 10, 'hello', 8.6]
print(10 in lst) # ==>True
print(99 in lst) # ==>False
print(100 not in lst) # ==>True

④ 列表元素的遍历

# 遍历列表
lst = ['hello', 'world', 10, 'hello', 8.6]
for item in lst:
print(item)
1.5 切片(获取列表中多个元素)

① 语法:列表名[start, stop, step]

② 切片的结果:原列表片段的拷贝

③ 切片的范围:[start, stop]

④ step默认为1:简写为[start, stop]

⑤ step为正数:从start开始往后计算切片

[:stop:step]切片的第一个元素默认是列表的第一个元素

[start::stop]切片的最后一个元素默认是列表的最后一个元素

⑥ step为负数:从start开始往前计算切片

[:stop:step]切片的第一个元素默认是列表的最后一个元素;

[start::stop]切片的最后一个元素默认是列表的第一个元素

# 切片练习
lis = [10, 20, 30, 40, 50, 60, 70, 80]
# start=1,stop=6,step=1
print(lis[1:6:1]) # ==>[20, 30, 40, 50, 60]
print(lis[1:6]) # 默认步长为1 (可写,可省略,也可不写) ==>[20, 30, 40, 50, 60]
print(lis[1:6:]) # ==>[20, 30, 40, 50, 60]
# start=1,stop=6,step=2
print(lis[1:6:2]) # ==>[20, 40, 60]
# start为空,stop=6,step=2
print(lis[:6:2]) # start为空,则从0开始 ==>[10, 30, 50]
# start=1,stop为空,step=2
print(lis[1::2]) # stop为空,则从指定位置查到最后一个元素 ==>[20, 40, 60, 80] # step为负数
print('原列表:', lis) # ==>原列表: [10, 20, 30, 40, 50, 60, 70, 80]
print(lis[::-1]) # 将原列表反过来了 # ==>[80, 70, 60, 50, 40, 30, 20, 10]
# start=7,stop省略,step=-1
print(lis[7::-1]) # ==>[80, 70, 60, 50, 40, 30, 20, 10]
# start=6,stop=0,step=-2
print(lis[6:0:-2]) # ==>[70, 50, 30]
1.6 增加操作

① append():在列表的末尾添加一个元素

② extend():在列表的末尾至少添加一个元素

③ insert():在列表的任意位置添加一个元素

④ 切片:在列表的任意位置添加至少一个元素

# 添加元素练习
lst = [10, 20, 30]
lst.append(100)
print(lst) # ==>[10, 20, 30, 100] lst2 = ['hello', 'world']
lst.append(lst2) # 将lst2作为一个元素添加到列表末尾
print(lst) # ==>[10, 20, 30, 100, ['hello', 'world']] lst.extend(lst2) # 将lst2中每个元素添加到列表末尾
print(lst) # ==>[10, 20, 30, 100, ['hello', 'world'], 'hello', 'world'] lst.insert(1, 'python') # 添加到指定索引的位置
print(lst) # ==>[10, 'python', 20, 30, 100, ['hello', 'world'], 'hello', 'world'] lst3 = [True, False, 'hello']
lst[1:] = lst3 # 相当于把切片的内容全部切掉,然后添加新的元素
print(lst) # ==>[10, True, False, 'hello']
1.7 删除操作

① remove():一次只能删除一个,重复元素只删除第一个,元素不存在则报ValueError

② pop():删除一个指定索引位置上的元素,指定索引不存在抛出IndexError,不指定索引时删除列表中最后一个元素

③ 切片:一次至少删除一个元素

④ clear():清空列表

⑤ del:删除列表

# 删除练习
lis = [10, 20, 30, 40, 50, 60, 30]
# 从列表中移除一个元素,如果有重复的移除第一个
lis.remove(30)
print(lis) # ==>[10, 20, 40, 50, 60, 30]
# remove元素不存在报错
lis.remove(100)
print(lis) # ==>ValueError # pop删除指定索引的值
lis.pop(1)
print(lis) # ==>[10, 40, 50, 60, 30]
# pop删除索引不存在会报错
lis.pop(5)
print(lis) # ==>IndexError
# pop不指定参数,删除最后一个
lis.pop()
print(lis) # ==>[10, 40, 50, 60] # 切片:删除至少一个元素,但是会产生新的列表对象
new_lis = lis[1:3]
print('原列表:', lis) # ==>原列表: [10, 40, 50, 60]
print('新列表:', new_lis) # ==>新列表: [40, 50]
# 切片:不产生新的列表对象,而是删除原列表中的内容
lis[1:3] = []
print(lis) # ==>[10, 60] # 清除列表
lis.clear()
print(lis) # ==>[] # del是直接将列表对象删除,这个对象没有了,当前不能调用了
del lis
print(lis) # ==>NameError
1.8 修改操作

① 为指定索引的元素赋予一个新值

② 为指定的切片赋予一个新值

# 修改练习
lst = [10, 20, 30, 40]
lst[2] = 100 # 一次修改一个值
print(lst) # ==>[10, 20, 100, 40] lst[1:3] = [300, 400, 500, 600] # 修改至少一个值
print(lst) # ==>[10, 300, 400, 500, 600, 40]
1.9 排序操作

① sort():列表中所有元素按照从小到大的顺序排序,使用reverse=True,进行降序排列

② 内置函数sorted():可以指定reverse=True,进行降序排列,原列表不发生变化

# 排序操作
lis = [20, 40, 10, 98, 54]
# 调用sort方法,默认是升序,不产生新的列表
lis.sort()
print(lis) # ==>[10, 20, 40, 54, 98]
lis.sort(reverse=True)
print(lis) # ==>[98, 54, 40, 20, 10]
lis.sort(reverse=False)
print(lis) # ==>[10, 20, 40, 54, 98] # 直接使用内置函数排序,默认为升序,会产生新的列表对象
lis2 = [20, 40, 10, 98, 54]
new_lis2 = sorted(lis2)
print('原列表:', lis2) # ==>原列表: [20, 40, 10, 98, 54]
print('新列表:', new_lis2) # ==>新列表: [10, 20, 40, 54, 98]
# 降序排列
new_lis3 = sorted(lis2, reverse=True)
print(new_lis3) # ==>[98, 54, 40, 20, 10]

2、字典(dict)

2.1 什么是字典

python中内置的数据结构之一,与列表一样是一个可变序列。以键值对的方式存储数据,字典是一个无序的序列

2.2 创建

① 创建方式一:使用花括号

② 创建方式二:使用内置函数dict()

③ 创建方式三:使用内置函数zip()

# 使用{}来创建
score = {'张三': 100, '李四': 98, '王五': 45}
print(score)
print(type(score)) # 使用dict()创建
student = dict(name='jack', age=20)
print(student) # ==>{'name': 'jack', 'age': 20} # 创建一个空字典
d = {}
print(d) # 使用内置函数zip
items = ['fruits', 'books', 'other']
prices = [98, 78, 67, 100, 102]
d = {item: price for item, price in zip(items, prices)}
print(d) # 使用zip函数时会以短的为基准,多余的忽略 ==>{'fruits': 98, 'books': 78, 'other': 67}# 使用{}来创建
score = {'张三': 100, '李四': 98, '王五': 45}
print(score)
print(type(score))
2.3 特点

① 字典中的所有元素都是一个key-value对,key不允许重复,vlaue可以重复

② 字典中的元素是无序的

③ 字典中的key必须是不可变对象

④ 字典也是可以根据需要动态的伸缩

⑤ 字典会浪费较大的内存,是一种使用空间换时间的数据结构

2.4 元素查询

① []

② get()方法

③ []和get()取值的区别:[]如果字典中不存在指定的key,抛出keyError异常;get()取值,如果字典中不存在指定key,不会拋异常而是返回None,可以通过参数设置默认的vlaue,可以在key不存在时返回

# 元素查询[]方式
score = {'张三': 100, '李四': 98, '王五': 45}
# 方式一:[]方式
print(score['张三'])
print(score['陈六']) # key不存在时会报KeyError # 方式二:get方式
print(score.get('张三'))
print(score.get('陈六')) # ==>None
print(score.get('拉拉', 99)) # ==>99是查找拉拉时如果不存在返回的默认值
2.5 常用操作

① key的判断:in / not in

② 元素的删除:del / clear()

③ 元素的新增:直接指定key对应的值

score = {'张三': 100, '李四': 98, '王五': 45}
# key的判断
print('张三' in score) # ==>True
print('张三' not in score) # ==>False # 删除元素
del score['张三'] # 删除指定的key-vlaue对
print(score) # ==>{'李四': 98, '王五': 45}
score.clear() # 清空字典中所有元素
print(score) # ==>{} # 新增元素
score['哈哈'] = 50 # 新增时若key不存在则新增
print(score) # ==>{'李四': 98, '王五': 45, '哈哈': 50}
# 修改元素
score['哈哈'] = 100 # 新增时若key存在则修改key对应的value值
print(score) # ==>{'李四': 98, '王五': 45, '哈哈': 100}
2.6 获取字典视图

① keys():获取字典中所有key

② values():获取字典中所有vlaue值

③ items():获取字典中所有key,vlaue对

score = {'张三': 100, '李四': 98, '王五': 45}
# 获取所有的key
keys = score.keys()
print(keys) # ==>dict_keys(['张三', '李四', '王五'])
print(type(keys)) # ==><class 'dict_keys'>
print(list(keys)) # 将key转化为list列表格式 ==>['张三', '李四', '王五'] # 获取所有的value
values= score.values()
print(values) # ==>dict_values([100, 98, 45])
print(type(values)) # ==><class 'dict_values'>
print(list(values)) # ==>[100, 98, 45] # 获取所有key-value
items = score.items()
print(items) # ==>dict_items([('张三', 100), ('李四', 98), ('王五', 45)])
print(type(items)) # ==><class 'dict_items'>
print(list(items)) # ==>[('张三', 100), ('李四', 98), ('王五', 45)]
2.7 字典元素的遍历
score = {'张三': 100, '李四': 98, '王五': 45}
# 字典的遍历
for item in score:
print(item) # ==> 输出的是字典中的key
print(score[item]) # ==> 输出的是字典中的value
print(score.get(item)) # ==> 输出的是字典中的value

3、元组(tuple)

3.1 元组:不可变序列
3.2 创建

① 创建方式一:使用小括号

② 创建方式二:使用内置函数tuple()

③ 创建方式三:只包含一个元组的元素需要使用逗号和小括号

# 方式一
t = ('python', 'world', 98)
print(t)
print(type(t))
t2 = 'python', 'world', 98 # 小括号可以省略
print(t2)
print(type(t2)) # 方式二
t1 = tuple(('python', 'world', 98))
print(t1)
print(type(t1)) # 方式三:创建一个元素的元组
t3 = ('python',) # 只有一个元素时必须加上逗号
print(t3)
print(type(t3))
# 空元组创建
t4 = ()
print(t4)
print(type(t4))
t5 = tuple()
print(t5)
print(type(t5))
3.3 为什么元组是不可变序列

① 在多任务环境下,同时操作对象时不需要加锁,因此在程序中尽量使用不可变序列

② 元组中存储的是对象的引用。

③ 如果元组中对象本身不可对象,则不能在引用其他对象

④ 如果元组中的对象是可变对象,则可变对象的引用不允许改变,但是数据可以改变

t = (10, [20, 30], 9)
print(t[0], type(t[0]))
print(t[1], type(t[1]))
print(t[2], type(t[2]))
# 修改t[1]:不允许修改元素type,可以改变列表中的数据
t[1].append(100)
print(t) # ==>(10, [20, 30, 100], 9)
3.4 元组的遍历

① 使用索引:前提是知道有多少个元素,超出索引号则报错

② for-in循环

# 元组遍历
t = ('python', 'world', 98)
# 方式一:使用索引
print(t[0])
print(t[1])
print(t[2])
# 方式二:使用for-in
for item in t:
print(item)

4、集合(set)

4.1 什么是集合

① 内置数据结构

② 属于可变类型的序列

③ 集合是没有vlaue的字典

4.2 创建

① 创建方式一:使用花括号

② 创建方式二:使用内置函数set()

③ 创建方式三:集合生成式

# 集合的创建
# 方式一
s = {1, 2, 3, 4, 5, 4, 3, 6, 7}
print(s) # ==>{1, 2, 3, 4, 5, 6, 7}
# 方式二
s = set(range(6))
print(s) # ==>{0, 1, 2, 3, 4, 5}
# 列表转化集合,同时去掉重复元素
print(set([3, 4, 55, 59, 3])) # ==>{59, 3, 4, 55}
# 元组转化集合
print(set((4, 5, 6, 7))) # ==>{4, 5, 6, 7}
# 字符串转化集合
print(set('python')) # ==>{'h', 'n', 't', 'p', 'o', 'y'}
# 集合转化集合
print(set({9, 8, 7, 6})) # ==>{8, 9, 6, 7}
# 空集合:直接使用{}不行,{}默认是空字典
print(set()) # ==> set()
# 利用生成式
s = {i for i in range(1, 10)}
print(s) # ==>{1, 2, 3, 4, 5, 6, 7, 8, 9}
4.3 特点

① 集合中的元素不能重复,若重复会直接去重

② 集合的元素是无序的

③ 是一个可变序列

4.4 判断操作:in / not in
# 判断操作
s = {10, 20, 30, 40, 50}
print(10 in s) # ==>True
print(100 not in s) # ==>True
print(100 in s) # ==>False
4.5 新增操作

① add():一次添加一个元素

② update():至少添加一个元素

# 新增
s = {10, 20, 30, 40, 50}
s.add(233) # 一次添加一个元素
print(s) # ==>{40, 233, 10, 50, 20, 30}
s.update({99, 88, 77}) # 一次至少添加一个元素
print(s) # ==>{99, 40, 233, 10, 77, 50, 20, 88, 30}
# 这个过程只是叭里面对应的元素加到集合中,而不是叭列表这个对象添加到集合
s.update([100, 101, 102])
print(s) # ==>{99, 100, 101, 102, 40, 233, 10, 77, 50, 20, 88, 30}
s.update((222, 333, 444))
print(s) # ==>{99, 100, 101, 102, 40, 233, 10, 77, 333, 50, 20, 88, 444, 222, 30}
4.6 删除操作

① remove():一次删除一个元素,如果元素不存在则抛出KeyError

② discard():一次删除一个指定元素,如果元素不存在不抛出异常

③ pop():一次至删除一个元素,不能指定参数

④ clear():清空集合

# 删除练习
s = {10, 20, 30, 40, 50}
s.remove(10)
print(s) # ==>{40, 50, 20, 30}
# s.remove(500)
print(s) # 抛出异常:KeyError s.discard(500) # 不会抛出异常
print(s) # ==> {40, 50, 20, 30} s.pop() # 不能指定参数,使用后删除任意一个元素
print(s) s.clear()
print(s) # ==>set()
4.7 集合间的关系

① 判断是否相等:== / !=

② 判断是否是子集:issubset()

③ 判断是否是超集:issuperset()

④ 判断是否没有交集:isdisjoint()

# 集合关系练习
s1 = {10, 20, 30, 40}
s2 = {30, 40, 20, 10}
# 判断集合是否相等:元素相同就相等
print(s1 == s2) # ==>True
print(s1 != s2) # ==>False s1 = {10, 20, 30, 40, 50, 60}
s2 = {10, 20, 30, 40}
s3 = {10, 20, 90}
# 判断是否是子集
print(s2.issubset(s1)) # ==>True
print(s3.issubset(s1)) # ==>False
# 判断是否是超集
print(s1.issuperset(s2)) # ==>True
print(s1.issuperset(s3)) # ==>False
# 判断是否是没有有交集: 没有交集返回True,有交集返回False
print(s1.isdisjoint(s2)) # ==>False
print(s2.isdisjoint(s1)) # ==>False
print(s1.isdisjoint(s3)) # ==>False
print(s2.isdisjoint(s3)) # ==>False
s4 = {100, 200, 300}
print(s4.isdisjoint(s3)) # ==>True
4.8 集合间的数学计算

① 交集:intersection()

② 并集:union()会自己去重操作

③ 差集:difference()

④ 对称差集:symmetric_difference()

# 数学计算
# 交集
s1 = {10, 20, 30, 40}
s2 = {20, 30, 40, 50, 60}
print(s1.intersection(s2)) # ==>{40, 20, 30}
print(s1 & s2) # ==>{40, 20, 30}
# 并集
print(s1.union(s2)) # ==>{40, 10, 50, 20, 60, 30}
print(s1 | s2) # ==>{40, 10, 50, 20, 60, 30}
# 差集:先计算交集,在从当中去除交集元素
print(s1.difference(s2)) # ==>{10}
print(s1 - s2) # ==>{10}
# 对称差集:先计算交集,然后两个集合同时去除交集后的数据的集合
print(s1.symmetric_difference(s2)) # ==>{50, 10, 60}
print(s1 ^ s2) # ==>{50, 10, 60}

5、列表、字典、元组、集合总结

【Python】容器:列表(list)/字典(dict)/元组(tuple)/集合(set)的更多相关文章

  1. Python基础 数据类型 (字符串、列表、字典、元组、集合、堆、栈、树)

    数据类型有整型.布尔.字符串.列表.字典.元组.集合.堆.栈和树. 1.整型: 整型就是数字 数字表示 python2 64位机器,范围-2^63~2^63-1 超出上述范围,python自动转化为l ...

  2. Python3中列表、字典、元组、集合的看法

    文首,我先强调一下我是一个弱鸡码农,这个随笔是在我学习完Python3中的元组.字典.列表,集合这四种常见数据的数据类型的一些感想,如果有什么不对的地方欢迎大家予以指正.谢谢大家啦 回归正题:这篇随笔 ...

  3. Python学习三|列表、字典、元组、集合的特点以及类的一些定义

    此表借鉴于他人 定义 使用方法 列表 可以包含不同类型的对象,可以增减元素,可以跟其他的列表结合或者把一个列表拆分,用[]来定义的 eg:aList=[123,'abc',4.56,['inner', ...

  4. Python中几种数据结构的整理,列表、字典、元组、集合

    列表:shoplist = ['apple', 'mango', 'carrot', 'banana']字典:di = {'a':123,'b':'something'}集合:jihe = {'app ...

  5. Python数据结构:列表、字典、元组、集合

    列表:shoplist = ['apple', 'mango', 'carrot', 'banana']字典:di = {'a':123,'b':'something'}集合:jihe = {'app ...

  6. Python基础 之列表、字典、元组、集合

    基础数据类型汇总 一.列表(list) 例如:删除索引为奇数的元素 lis=[11,22,33,44,55] #第一种: for i in range(len(lis)): if i%2==1: de ...

  7. python(字符串、列表、字典、元组、集合)的常用内置方法

    一.字符串: lis='my name is maple' res=lis.count('m')#计算字符串内相同字符的个数 print(res) lis='my name is maple' res ...

  8. python--列表、字典、元组、集合对比

    数据类型# 计算机能处理的远不止数值,还可以处理文本.图形.音频.视频.网页等各种各样的数据,不同的数据,需要定义不同的数据类型.# a:整形和浮点型(正数和负数)# b:布尔类型(true,fals ...

  9. python 数据类型: 字符串String / 列表List / 元组Tuple / 集合Set / 字典Dictionary

    #python中标准数据类型 字符串String 列表List 元组Tuple 集合Set 字典Dictionary 铭记:变量无类型,对象有类型 #单个变量赋值 countn00 = '; #整数 ...

  10. Python学习,第五课 - 列表、字典、元组操作

    本篇主要详细讲解Python中常用的列表.字典.元组相关的操作 一.列表 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 通过下标获取元素 #先定义一个列表 le ...

随机推荐

  1. Java后台校验手机号和邮箱

    //true是手机号,false不是手机号 public static boolean checkPhone(String phone){ Pattern p = Pattern.compile(&q ...

  2. fabric学习笔记8

    fabric学习笔记8 20201303张奕博 2023.1.19 具体结构: Wallet中的X.509数字证书将组织和持有者联系起来,使得持有者能够有权限连接到网络,不同的持有者身份拥有不同的权限 ...

  3. C++语言程序设计实验一 类与对象

    Complex.hpp文件源码: #include <iostream> using namespace std; class Complex { public: Complex(floa ...

  4. Ubuntu系统安装搜狗拼音输入法

    问题背景 Ubuntu是使用人数最多的Linux发行版之一,其丰富的生态广受各位种花家程序员小伙伴们的欢迎.对种花家小伙伴们来说,最重要的功能之一就是中文输入法了.但是Ubuntu自带的中文输入法效果 ...

  5. DotNetCore2.1镜像上传DockerHub在Docker运行

    操作步骤: 1.本地安装Docker(此处省略安装过程) 2.登录Docker 3.浏览器打开官方DockerHub地址注册用户(注意:注册操作需要FQ才能成功,后期登录和其他操作使用国内网络都可以) ...

  6. Java面向对象之什么是继承?

    继承 继承的本质是对某一批类的抽象,从而实现对现实世界更好的建模. extends的意思是"扩展".子类是父类的扩展. Java中类只有单继承,没有多继承!即 一个儿子只能有一个爸 ...

  7. function的length,就是第一个具有默认值之前的参数个数。

    一个拥有 length 属性和若干索引属性的对象就可以被称为类数组对象,类数组对象和数组类似,但是不能调用数组的方法.常见的类数组对象有 arguments 和 DOM 方法的返回结果,还有一个函数也 ...

  8. cookie,session,token,drf-jwt

    1.cookie,session,token发展史 引入:我们都知道 http 协议本身是一种无状态的协议,一个普通的http请求简单分为三步:客户端发送请求request服务端收到请求并进行处理服务 ...

  9. 【Java SpringBoot】RestTemplate使用postForObject发送请求,接收String类型的response时中文乱码

    https://blog.csdn.net/qq_43758789/article/details/120576717 使用RestTemplate发送PostForObject的时候会出现乱码.这是 ...

  10. SAR成像(四):多普勒频移的计算

    雷达系统中,雷达与目标间的相互运动会使回波信号产生频移,称为多普勒效应,对应的频移称为多普勒频率. 假设雷达发射信号为单频连续波, f ( t ) = c o s ( 2 π f 0 t + ϕ ) ...