gpt4 book ai didi

python-3.x - 逐列特定值计数

转载 作者:行者123 更新时间:2023-12-05 01:13:10 24 4
gpt4 key购买 nike

aMat=df1000.iloc[:,1:].values
print(aMat)

通过使用上面的代码,我从数据集中得到了下面提到的数据矩阵:

[[1 2 5 2 4]
[1 2 1 2 2]
[1 2 4 2 4]
[1 5 1 1 4]
[1 4 4 2 5]]

数据集只能容纳 1,2,3,4 和 5 个值。所以我想计算第一列中出现的 1 个数,第一列中出现的 2 个数,第一列中出现的 3 个数,第一列中出现的 4 个数,第一列中出现的 5 个数,第一个列中出现的 1 个数第二列,......等等。意味着最后列表将如下所示:

[[5,0,0,0,0],[0,3,0,1,1],[2,0,0,2,5],[1,4,0,0,0],[0,1,0,3,1]]

请帮忙

最佳答案

让我们试试:

df = pd.DataFrame([[1, 2, 5, 2, 4],
[1, 2, 1, 2, 2],
[1, 2, 4, 2, 4],
[1, 5, 1, 1, 4],
[1, 4, 4, 2, 5]])

df.apply(pd.Series.value_counts).reindex([1,2,3,4,5]).fillna(0).to_numpy('int')

输出:

array([[5, 0, 2, 1, 0],
[0, 3, 0, 4, 1],
[0, 0, 0, 0, 0],
[0, 1, 2, 0, 3],
[0, 1, 1, 0, 1]])

或者,转置:

df.apply(pd.Series.value_counts).reindex([1,2,3,4,5]).fillna(0).T.to_numpy('int')

输出:

array([[5, 0, 0, 0, 0],
[0, 3, 0, 1, 1],
[2, 0, 0, 2, 1],
[1, 4, 0, 0, 0],
[0, 1, 0, 3, 1]])

关于python-3.x - 逐列特定值计数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56428374/

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