如何对Python列表进行切片,以便将一列移动为单独的元素列?

2024-06-26 12:38:22 发布

您现在位置:Python中文网/ 问答频道 /正文

我有以下表格:

[[0, 5.1, 3.5, 1.4, 0.2],
 [0, 4.9, 3.0, 1.4, 0.2],
 [0, 4.7, 3.2, 1.3, 0.2],
 [1, 4.6, 3.1, 1.5, 0.2],
 [1, 5.0, 3.6, 1.4, 0.2],
 [1, 5.4, 3.9, 1.7, 0.4],
 [1, 4.6, 3.4, 1.4, 0.3]]

我希望将第一列切片,并将其作为新元素添加到每行数据中(因此在列表中的每个奇数位置),将其更改为以下形式:

^{pr2}$

我怎么能这么做?在

到目前为止,我通过以下方式提取了必要的信息:

targets = [element[0] for element in dataset]
features = dataset[1:]

Tags: 数据in信息列表for方式切片element
3条回答

列表理解很好,但可能有点难扫描。循环仍然有用,尤其是与extend结合使用时:

res = []
for entry in dataset:
    res.extend([entry[1:], entry[:1]])

现在:

^{pr2}$

印刷品:

[[5.1, 3.5, 1.4, 0.2],
 [0],
 [4.9, 3.0, 1.4, 0.2],
 [0],
 [4.7, 3.2, 1.3, 0.2],
 [0],
 [4.6, 3.1, 1.5, 0.2],
 [1],
 [5.0, 3.6, 1.4, 0.2],
 [1],
 [5.4, 3.9, 1.7, 0.4],
 [1],
 [4.6, 3.4, 1.4, 0.3],
 [1]]

尝试索引,然后得到扁平化列表-我使用列表理解来扁平化。在

>>>l=[[0, 5.1, 3.5, 1.4, 0.2],
 [0, 4.9, 3.0, 1.4, 0.2],
 [0, 4.7, 3.2, 1.3, 0.2],
 [1, 4.6, 3.1, 1.5, 0.2],
 [1, 5.0, 3.6, 1.4, 0.2],
 [1, 5.4, 3.9, 1.7, 0.4],
 [1, 4.6, 3.4, 1.4, 0.3]]
>>>[[i[1:],[i[0]]] for i in l]#get sliced list of lists
>>>[[[5.1, 3.5, 1.4, 0.2], [0]], [[4.9, 3.0, 1.4, 0.2], [0]], [[4.7, 3.2, 1.3, 0.2], [0]], [[4.6, 3.1, 1.5, 0.2], [1]], [[5.0, 3.6, 1.4, 0.2], [1]], [[5.4, 3.9, 1.7, 0.4], [1]], [[4.6, 3.4, 1.4, 0.3], [1]]]
>>>d=[[i[1:],[i[0]]] for i in l]
>>>[item for sublist in d for item in sublist]#flatten list d
>>>[[5.1, 3.5, 1.4, 0.2], [0], [4.9, 3.0, 1.4, 0.2], [0], [4.7, 3.2, 1.3, 0.2], [0], [4.6, 3.1, 1.5, 0.2], [1], [5.0, 3.6, 1.4, 0.2], [1], [5.4, 3.9, 1.7, 0.4], [1], [4.6, 3.4, 1.4, 0.3], [1]]

仅限一条线备选方案-

^{pr2}$

试试这个:

from itertools import chain
print list(chain(*[list((element[1:],[element[0]])) for element in a]))

输出:

^{pr2}$

相关问题 更多 >