如何在pandas中用列名替换值

我正在尝试使用Last.fm的数据构建一个推荐系统,以推荐用户可能会喜欢的歌曲。

我使用NearestNeighbors算法来预测用户可能会喜欢的歌曲特征。我已经建立了模型,但遇到的问题是,在Pandas DataFrame中,我得到的是整数值而不是歌曲名称。这是我的结果截图

enter image description here

我希望在数据集中值部分显示歌曲名称而不是数字。我该如何实现这一点?这是输出应有的样子:

enter image description here这是我的Ipython笔记本的链接: http://nbviewer.ipython.org/github/kartikjagdale/Last.fm-Song-Recommender/blob/master/Ipython%20Notebook/Last.Fm%20Song%20Recommeder.ipynb

这是我的GitHub项目的链接: https://github.com/kartikjagdale/Last.fm-Song-Recommender/


回答:

DataFrame.columns 是一个 Index 对象,可以作为数组使用。

你可以使用 pd.DataFrame(df.columns[model]) 来获取名称,这里是一个示例:

import pandas as pdimport numpy as npfrom sklearn.neighbors import NearestNeighborsdf = pd.DataFrame(np.random.randint(0, 5, (10, 5)), columns=list("ABCDE"))neigh = NearestNeighbors(n_neighbors=3)neigh.fit(df.T) # 拟合数据model = neigh.kneighbors(df.T, return_distance=False)pd.DataFrame(df.columns[model])

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注