Python中关于list用法汇总(多层列表)
1 、增加
import numpy as np
arr = [[[0, 0, 0, 0, 1],[1, 1, 0, 1, 0]],
[[1, 0, 1, 1, 0],[1, 0, 0, 1, 0]],
[[1, 0, 0, 0, 1],[1, 1, 0, 1, 0]]]
a = [[1, 1, 0, 0 ,1],[1,0, 0, 0, 0]]
arr.append(a) #在末尾添加// extend()增加一个列表
print(arr)
arr.insert(1, a)#在指定位置添加
print(arr)
结果:
在末尾添加[[[0, 0, 0, 0, 1], [1, 1, 0, 1, 0]],
[[1, 0, 1, 1, 0], [1, 0, 0, 1, 0]],
[[1, 0, 0, 0, 1], [1, 1, 0, 1, 0]],
[[1, 1, 0, 0, 1], [1, 0, 0, 0, 0]]]
在指定位置添加[[[0, 0, 0, 0, 1], [1, 1, 0, 1, 0]],
[[1, 1, 0, 0, 1], [1, 0, 0, 0, 0]],
[[1, 0, 1, 1, 0], [1, 0, 0, 1, 0]],
[[1, 0, 0, 0, 1], [1, 1, 0, 1, 0]]]
补充:extend()
extend()对于列表的操作主要实现的是对于特定列表的扩展和增长,可以一次添加多个元素,不过也只能添加在列表的最后;
m.extend([元素A,元素B,……])
2、删除
(1)remove:指定元素删除
arr.remove([[1, 0, 1, 1, 0], [1, 0, 0, 1, 0]])
print(arr)
结果:
[[[0, 0, 0, 0, 1], [1, 1, 0, 1, 0]], [[1, 0, 0, 0, 1], [1, 1, 0, 1, 0]]]
(2)del:依据元素的下标删除
del arr[1]
print(arr)
结果:
[[[0, 0, 0, 0, 1], [1, 1, 0, 1, 0]], [[1, 0, 0, 0, 1], [1, 1, 0, 1, 0]]]
(3)pop:删除最后一个
arr.pop()
print(arr)
结果:
[[[0, 0, 0, 0, 1], [1, 1, 0, 1, 0]], [[1, 0, 1, 1, 0], [1, 0, 0, 1, 0]]]
3、返回列表中值为固定值的位置信息
arr = [[[0, 0, 0, 0, 1],[1, 1, 0, 1, 0]],
[[1, 0, 1, 1, 0],[1, 0, 0, 1, 0]],
[[1, 0, 0, 0, 1],[1, 1, 0, 1, 0]]]
arr1 = np.array(arr)
idx = np.array(np.where(arr1 == 1)).tolist()
coordinates = [(x, y, z) for x, y, z in zip(idx[0], idx[1], idx[2])]
print(coordinates)
结果:
[(0, 0, 4), (0, 1, 0), (0, 1, 1), (0, 1, 3), (1, 0, 0), (1, 0, 2), (1, 0, 3), (1, 1, 0), (1, 1, 3), (2, 0, 0), (2, 0, 4), (2, 1, 0), (2, 1, 1), (2, 1, 3)]
4、排序
(1)sort:顺序
(2)倒序
1)list.reverse() 方法,会直接在原来的列表里面将元素进行逆序排列,不需要创建新的副本用于存储结果,不需要重新申请空间来保存最后的结果,但是修改了原来的数据。
2)Python 的列表有一个特性叫做切片,mylist[:] 会返回 mylist 的副本,当start 、end 和 step 为负时,表示从反方向遍历,所以 mylist[::-1] 就能达到逆序的目的。相比于第一种方式,这种方式会另外创建副本来保存列表的所有元素,所以需要更多的内存空间。
3)reversed 方法会将列表逆序的结果存储到迭代器里面,这种方式不会改变原来的列表,也不会创建原来列表的完整副本,只会多出迭代器对象所占的空间,相对来说也比较高效。也就是说其返回值是一个迭代器,你可以将其理解为一个指针,指向原来的列表。
(3)shuffle:乱序
from random import shuffle
shuffle(arr)
print(arr)
结果:
[[[1, 0, 1, 1, 0], [1, 0, 0, 1, 0]], [[1, 0, 0, 0, 1], [1, 1, 0, 1, 0]], [[0, 0, 0, 0, 1], [1, 1, 0, 1, 0]]]