python核心数据类型 -- 列表类型

列表为容器类型可变可异构可嵌套对象,可以通过索引访问列表元素

定义列表的方式

list1 = []
list1 = list()


原处修改

实际上是修改元素引用

修改指定索引的元素

list1[1] = 2 --> 修改列表的第2个元素

修改指定的分片

list1[2:4] = [3, 4] --> 修改列表的第3,4个元素

删除指定索引的元素

list1[1:2] = [] --> 删除列表的第2个元素

删除指定的分片

list1[1:3] = [] --> 删除列表的第2,3个元素

删除语句

del(list1[2:]) --> 删除列表的第2个以后的所有元素


适用于列表的操作 内置方法

追加

L.append(object) -> append object to end:将对象作为元素追加到列表
L.extend(iterable) -> extend list by appending elements from the iterable:将可迭代对象的元素附加到列表

插入

L.insert(index, object) -- insert object before index 在指定位置之前插入一个元素

删除

L.pop([index]) -> item -- remove and return item at index (default last)删除指定索引的元素IndexError
L.remove(value) -- remove first occurrence of value.删除指定值的元素ValueError

计数

L.count(value) -> integer -- return number of occurrences of value 统计指定值出现的次数

排序

L.sort()正向原处排序
L.reverse() -- reverse IN PLACE 逆向原处排序

查找

L.index(value, [start, [stop]]) -> integer -- return first index of value.
查找列表元素第一次出现的位置ValueError

L.append(X) <==> L[len(X):] = [X]


列表复制

l2 = l1 :赋值后实际指向同一个内存对象,两个是同步
l3 = l1[:] :赋值后实际指向内存对象不同,两个是不同步
l4 = copy.deepcopy(l1) :深度复制(copy模块),两个是不同步
l5 = [i for i in l2]:使用列表解析进行复制,两个是不同步


列表解析

生成列表

[ord(x) for x in 'Spaam']
[83, 112, 97, 97, 109]

生成集合

{ord(x) for x in 'Spaam'}
{83, 97, 109, 112}

生成字典

{x: ord(x) for x in 'Spaam'}
{'S': 83, 'a': 97, 'm': 109, 'p': 112}

生成器

M = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
G = (sum(row) for row in M)
G
G.netx() #用来访问
<generator object <genexpr> at 0x7fbd8387c910>

列表解析和for循环
squares = [ x ** 2 for x in [1, 2, 3]]
for x in [1, 2, 3]:
    squares.append(x ** 2)

通常优势考虑使用列表解析,速度快于for循环

转载于:https://www.cnblogs.com/hiavatar/p/6479323.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值