假设我有一份清单:
list = [[1, 2, 3, 4],
['a', 'b', 'c', 'd'],
[9, 8, 7, 6]]我想得到这样的东西:
newList = [[2, 3, 4],
['b', 'c', 'd'],
[8, 7, 6]]因此,我尝试使用这个解决方案。
print(list[0:][1:])但我得到了这个输出
[['a', 'b', 'c', 'd'],
[9, 8, 7, 6]]所以我试着
print(list[1:][0:])但我得到的结果完全一样。
我试着对这个特定的课题做了一些研究和实验,但没有结果。
发布于 2022-04-05 07:35:10
您希望的每个行的1结束元素在您的矩阵。
mylist = [[1, 2, 3, 4],
['a', 'b', 'c', 'd'],
[9, 8, 7, 6]]
new_list = [row[1:] for row in mylist]发布于 2022-04-05 07:54:31
我想解释一下,你做了什么
print(list[0:][1:])
print(list[1:][0:])首先,请注意python使用从0开始的索引,即对于1、2、3有第0元素、第1元素和第2元素。
[0:]的意思是从第0元素开始获取列表元素,这将给您列表的副本,[1:]的意思是从第1元素开始获取列表元素,这将为您提供除第0元素之外的所有列表。因此,这两条线是等价的,并且是
print(list[1:])您可能需要使用理解或map输出如下所示
list1 = [[1, 2, 3, 4], ['a', 'b', 'c', 'd'], [9, 8, 7, 6]]
list2 = list(map(lambda x:x[1:],list1))
print(list2)输出
[[2, 3, 4], ['b', 'c', 'd'], [8, 7, 6]]lambda这里是无名函数,请注意,这里的理解更容易理解,但如果您之前使用的语言具有类似的特性,例如JavaScript's map,则可能更容易消化。
发布于 2022-04-05 07:37:41
第一,不要把你的名单命名为“名单”!
a = [[1, 2, 3, 4],
['a', 'b', 'c', 'd'],
[9, 8, 7, 6]]
b = [x[1:] for x in a]
print(b)[2,3,4,'b','c','d',8,7,6]
https://stackoverflow.com/questions/71747824
复制相似问题