gpt4 book ai didi

python - Pandas 列由数组组成,使用 plt.imshow() 绘制

转载 作者:行者123 更新时间:2023-12-05 06:06:12 25 4
gpt4 key购买 nike

所以我的数据结构有点不寻常。这是我正在使用的示例:

import numpy as np
import pandas as pd

dict = {'data': [[1,2,3], [2,3,4], [3,4,5]], 'parameter': [10, 11, 12]}
df = pd.DataFrame(dict)

换句话说,df['data'] 中的每一行都包含一个数组。

我需要使用 matplotlib 的 imshow() 函数来绘制它,但我在使用 df['data'] 中的数组时遇到了困难。我试过使用 df['data'].to_numpy(),但这会返回一个 dtype=object,imshow 无法处理。尝试绘制时出现此错误:

TypeError: Image data of dtype object cannot be converted to float

准确地说,这是我尝试运行的:

import pylab as plt
plt.imshow(df['data'].to_numpy())

我四处阅读,似乎找不到任何人有类似的例子。

明确一点:我需要从 DataFrame imshow,我不能直接从我的代码中的字典中绘制。我也不想对新列表进行任何附加操作,因为我的数据集很大并且会大大降低速度。


编辑 1:

要回答评论中的问题,这就是我想要的情节类型。 x 轴包含 df['data'] 中的数组,而 y 轴最终将是 df['parameter']enter image description here


编辑 2:

我想我需要进一步澄清我的问题。我希望准确地重现这个情节。

enter image description here

为了制作这个情节,我做了以下事情:

rows = []
for i in df['data']:
rows.append(i)
plt.imshow(rows)

此解决方案适用于我的数据,但我正在寻找一种更有效的方法来完成同样的事情。即,一种不涉及循环和追加的方法。

最佳答案

您可以执行以下操作:

使用df.explodedata 列取消列出到不同的行,然后绘图。

x = df.explode('data').reset_index()
plt.imshow(x[['data','parameter']].to_numpy().astype('float').T)

这将产生:

enter image description here

基本上,x[['data','parameter']].to_numpy().astype('float').T 将为您提供所需的 numpy 数组,您可以在其中绘制愿望。

根据用户评论编辑:

plt.imshow(np.array(df["data"].values.tolist()).astype('float'))

这将产生:

enter image description here

关于python - Pandas 列由数组组成,使用 plt.imshow() 绘制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65840855/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com