微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用 dtype float 将 pandas.Multindex 转换为 numpy.ndarray

如何解决使用 dtype float 将 pandas.Multindex 转换为 numpy.ndarray

将 pandas.Multiindex 转换为 numpy.ndarray 时,输出是带有 dtype=object 的一维 ndarray,如下例所示:

df = pd.DataFrame({
    'A': [10,20,30,40,50,60],'B': [0,1,2,3,4,5],'C': ['K0','K1','K2','K3','K4','K5']
}).set_index(['A','B'])

df 将是:

A B C
10 0 K0
20 1 K1
30 2 K2
40 3 K3
50 4 K4
60 5 K5

df.index.to_numpy()输出是带有 dtype=object 的一维数组:

array([(10,0),(20,1),(30,2),(40,3),(50,4),(60,5)],dtype=object)

但我想要:

array([[10,0],[20,1],[30,2],[40,3],[50,4],[60,5]])

How to convert a Numpy 2D array with object dtype to a regular 2D array of floats,我找到了以下解决方案:

np.vstack(df.index)

有没有更直接或更好的解决方案?

解决方法

我很确定您将通过展平多索引并从结果中获取 numpy 数组来获得您想要的结果。例如。通过使用以下语法

np.array(list(df.index))
,

将索引转为列。

df.reset_index()[['A','B']].values

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。