浅谈list,tuple,dict和get

本文面向Python初学者,详细介绍了list、tuple、dict和set的基础概念、创建方式、常用操作及其特点。list是可变有序集合,允许不同类型的元素;tuple是不可变有序集合,常用于需要固定数据的情况;dict是键值对存储,查找速度快,适合高速查找;set是无序且不重复的元素集合,支持集合运算。理解这些数据结构有助于提高Python编程效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为什么要谈list/tuple/dict/get 了,作为一个刚开始学习python的菜鸟来说,当我学到函数那一块是各种的各种值数组一累加,我当时就蒙了,还不能完全了解,因此我就它整理了一下希望对更我一样的迷茫的菜鸟有点小小的帮助!
接下来就新介绍这几个词的大致说发与用法吧!(有错误的话还请大神指出来,我会好好改正)

list

Python内置的一种数据类型是列表:list。list是一种有序的集合,可以随时添加和删除其中的元素。
而且list里面的元素的类型可以不一样
创建方式:a=[‘dsa’,123,True]
查看方式:
1. 直接输入 : a
2. a加索引 : a[0] 这是从前往后数第一个元素 而a[-1]是从后往往前数倒数第一个
获取a的长度用: len(a)
list的添加函数:a.append(‘dsaf’)
list的插入函数:a.inser(1,‘dfsd’)
list的删除末尾的元素:a.pop() 也可以指定删除a.pop(i) i为索引数
list的元素替换:a[i]=‘字符’ i为要替换的值得索引数

tuple

另一种有序列表叫元组:tuple。tuple和list非常类似,但是tuple一旦初始化就不能修改,但是ltuple里面的元素的类型可以不一样,可以结合list改变tuple的初始化不能改变的局面
创建方式:b=(‘dsa’,123,True)’
查看方式:
1. 直接输入 : b
2. b加索引 : b[0] 这是从前往后数第一个元素 而a[-1]是从后往往前数倒数第一个
解决tuple一旦初始化就不能修改:
t = (‘a’, ‘b’, [‘A’, ‘B’])其中t有三个元素不要看错,[‘A’,‘B’]是list素组算一个元素
改变的方法为:t[2][0]=‘C’
结果就是:(‘a’, ‘b’, [‘C’, ‘B’])

dict

Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。
创建方式:c={‘Michael’: 95, ‘Bob’: 75, ‘Tracy’: 85}
查看方式:c[‘Michael’]/c
查询值是否存在: ‘Michael’ in c,c.get(‘Michael’) 不存在返回 None
删除值用: c.pop(‘Michael’)

set

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。
要创建一个set,需要提供一个list作为输入集合:
创建方式:s=set([1, 1, 2, 2, 3, 3])它会自动过滤重复的数值
查看方式:c
添加方式:s.aad(key)
删除方式:s.remove(key)
set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作:
s1 = set([1, 2, 3])
s2 = set([2, 3, 4])
s1 & s2
=============结果
{2, 3}
》》》s1 | s2
=================结果
{1, 2, 3, 4}

==============================================
和list比较,dict有以下几个特点:
查找和插入的速度极快,不会随着key的增加而变慢;
需要占用大量的内存,内存浪费多。
而list相反:
查找和插入的时间随着元素的增加而增加;
占用空间小,浪费内存很少。
所以,dict是用空间来换取时间的一种方法。
dict可以用在需要高速查找的很多地方,在Python代码中几乎无处不在,正确使用dict非常重要,需要牢记的第一条就是dict的key必须是不可变对象。
这是因为dict根据key来计算value的存储位置,如果每次计算相同的key得出的结果不同,那dict内部就完全混乱了。这个通过key计算位置的算法称为哈希算法(Hash)。
要保证hash的正确性,作为key的对象就不能变。在Python中,字符串、整数等都是不可变的,因此,可以放心地作为key。而list是可变的,就不能作为key:

如有错误,请大佬们指点!O~O 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值