Pandas:TypeError:sort_values()缺少1个必需的位置参数:'by'

时间:2017-02-25 20:03:53

标签: python pandas jupyter

我面临TypeError:sort_values()缺少1个必需的位置参数:'by'

for i in range(0,len(data_sims.index)):
for j in range(1,len(data_sims.columns)):
    user = data_sims.index[i]
    serial = data_sims.columns[j]

    if dataUser.ix[i][j] == 1:
        data_sims.ix[i][j] = 0
    else:
        serial_top_names = data_neighbours.ix[serial][1:10]
        serial_top_sims = dataSim.ix[serial].sort_values(ascending=False)[1:10]
        user_preferences = dataUser.ix[user,serial_top_names]

        data_sims.ix[i][j] = getScore(user_preferences,serial_top_sims)

详细错误:

> ---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
 in ()
      9         else:
     10             serial_top_names = data_neighbours.ix[serial][1:10]
---> 11             serial_top_sims = dataSim.ix[serial].sort_values(ascending=False)[1:10]
     12             user_preferences = dataUser.ix[user,serial_top_names]
     13 

TypeError: sort_values() missing 1 required positional argument: 'by'

我尝试使用以下但没有工作

pd.DataFrame.sort_values(dataSim,ascending=[0])[1:10]

有什么我想念的吗?

2 个答案:

答案 0 :(得分:2)

documentation for Pandas提及:

DataFrame.sort_values(by,
                      axis=0,
                      ascending=True,
                      inplace=False,
                      kind='quicksort',
                      na_position='last')

by :str或str列表 引用轴项目的名称或名称列表。

在我的例子中:

df.groupby('product').agg({'weight':'sum'}).sort_values(by='weight')

添加='重量'解决了TypeError:sort_values()缺少1个必需的位置参数:' by'

答案 1 :(得分:1)

数据框可能有多个列,因此请指定要作为排序依据的列。

df = df.sort_values(by='sentence_length').reset_index(drop=True)