栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

2021-11-05

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

2021-11-05

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]]]
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/445316.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号