gpt4 book ai didi

python - 对独立于列的每一行绝对值以及列名进行排序

转载 作者:行者123 更新时间:2023-12-03 20:25:27 24 4
gpt4 key购买 nike

我有一个类似格式的数据框:

df = pd.DataFrame({
'p1': [0, 0, 1, 1, -2],
'p2': [9, 2, 3, -5, 3],
'p3': [1, 3, 10, 3, 7],
'p4': [4, 4, 7, 1, 10]})

p1 p2 p3 p4
0 0 9 1 4
1 0 2 3 4
2 1 3 10 7
3 1 -5 3 1
4 -2 3 7 10

预期输出:
top1    top2
p2:9 p4:4
p4:4 p3:3
p3:10 p4:7
p2:-5 p3:3
p4:10 p3:7

通过大量研究,我能够对排序数组的索引进行排序和获取。我还能够用列替换索引。但我无法将它们与行值连接起来。
nlargest = 3
order = np.argsort(-df.abs().values, axis=1)[:, :nlargest]
result = pd.DataFrame(df.columns[order],
columns=['top{}'.format(i) for i in range(1, nlargest+1)])

top1 top2 top3
0 p2 p4 p3
1 p4 p3 p2
2 p3 p4 p2
3 p2 p3 p1
4 p4 p3 p2

使用上述方法,我尝试对不同 DataFrame 中的行进行排序,后来想到将它们连接起来。但我找不到正确的方法来做到这一点。我知道这不是最佳方式。
result2 = pd.DataFrame(np.sort(df.values, axis=0), index=df.index, columns=df.columns)
result2 = result2.iloc[:, 0:nlargest]
result2.columns = columns=['top{}'.format(i) for i in range(1, nlargest+1)]

top1 top2 top3
0 -2 -5 1
1 0 2 3
2 0 3 3
3 1 3 7
4 1 9 10

请帮我纠正排序和获得预期格式的最短方法。

最佳答案

使用, DataFrame.transform 连同 DataFrame.lookup :

result = result.transform(lambda s: s + ':' + df.lookup(s.index, s).astype(str))
# print(result)
top1 top2 top3
0 p2:9 p4:4 p3:1
1 p4:4 p3:3 p2:2
2 p3:10 p4:7 p2:3
3 p2:-5 p3:3 p1:1
4 p4:10 p3:7 p2:3

关于python - 对独立于列的每一行绝对值以及列名进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62321915/

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