Python 列表类型

1. 作用

按位置存放多个值

2. 定义

l = [1, 1.2, 'a']  # l=list([1,1.2,'a'])
print(type(l))

3. 类型转换: 但凡能够被for循环遍历的类型都可以当做参数传给list()转成列表

res=list('hello')
print(res)

res=list({'k1':111,'k2':222,'k3':3333})
print(res)

4. 内置方法

  1. 按索引存取值(正向存取+反向存取):即可以取也可以改
l = [111, 'egon', 'hello']
# 正向取
print(l[0])
# 反向取
print(l[-1])
# 可以取也可以改:索引存在则修改对应的值
l[0] = 222
print(l)
  1. 切片(顾头不顾尾,步长)
l = [111, 'egon', 'hello', 'a', 'b', 'c', 'd', [1, 2, 3]]
print(l[0:3])
print(l[0:5:2])  # 0 2 4

print(l[0:len(l)])
print(l[:])
new_l = l[:]  # 切片等同于拷贝行为,而且相当于浅copy
print(id(l))
print(id(new_l))

l[-1][0] = 1111111
print(l)
print(new_l)

print(l[::-1])

msg1 = 'hello:egon:<>:18[]==123'
msg2 = msg1[:]
print(msg1, id(msg1))
print(msg2, id(msg2))

点击了解浅拷贝

  1. 长度
print(len([1, 2, 3]))
  1. 成员运算in和not in
print('aaa' in ['aaa', 1, 2])
print(1 in ['aaa', 1, 2])

5. 往列表中添加值

5.1 追加
l = [111, 'egon', 'hello']
l.append(3333)
l.append(4444)
print(l)
5.2 插入值
l = [111, 'egon', 'hello']
l.insert(0, 'alex')
print(l)
5.3 extend添加值
new_l=[1,2,3]
l=[111,'egon','hello']
l.append(new_l)
print(l)

6. 删除

  1. 通用的删除方法,只是单纯的删除、没有返回值
l = [111, 'egon', 'hello']
del l[1]
x =del l[1] # 抛出异常,不支持赋值语法
print(l)
  1. l.pop()根据索引删除,会返回删除的值
l = [111, 'egon', 'hello']
l.pop()  # 不指定索引默认删除最后一个
l.pop()
print(l)

res=l.pop(1)
print(l)
print(res)
  1. l.remove()根据元素删除,返回None
l = [111, 'egon', [1, 2, 3], 'hello']
l.remove([1, 2, 3])
print(l)
res = l.remove('egon')
print(res)  # None

7. 循环

l = [1, 'aaa', 'bbb']
for x in l:
	l.pop(1)
	print(x)
1. l.count()
print(l.count('aaa'))
2. l.index()
print(l.index('aaa'))
print(l.index('aaaaaaaaa'))  # 找不到报错
3. l.clear()
l.clear()
print(l)
4. l.reverse():不是排序,就是将列表倒过来
l = [1, 'egon', 'alex', 'lxx']
l.reverse()
print(l)
5. l.sort(): 列表内元素必须是同种类型才可以排序
l = [11, -3, 9, 2, 3.1]
l.sort()  # 默认从小到大排,称之为升序
l.sort(reverse=True)  # 从大到小排,设置为降序
print(l)

l=[11,'a',12]
l.sort()

l=['c','e','a']
l.sort()
print(l)

补充:

  1. 队列:FIFO,先进先出
l = []
# 入队操作
l.append('first')
l.append('second')
l.append('third')
print(l)

# 出队操作
print(l.pop(0))
print(l.pop(0))
print(l.pop(0))
  1. 堆栈:LIFO,后进先出
l = []
# 入栈操作
l.append('first')
l.append('second')
l.append('third')

print(l)
# 出队操作
print(l.pop())
print(l.pop())
print(l.pop())
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿过家家

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值