它是pandas/Dataframe,它包含每个人每天的所有分数,我想添加一个额外的列来收集它有最高分数的次数(可能不止一个人,一些数据是nan
)
import pandas as pd
import numpy as np
data = np.array([['','day1','day2','day3','day4','day5'],
['larry',1,4,7,3,5],
['niko',2,-1,3,6,4],
['tin',np.nan,5,5, 6,7]])
df = pd.DataFrame(data=data[1:,1:],
index=data[1:,0],
columns=data[0,1:])
print(df)
输出
day1 day2 day3 day4 day5
larry 1 4 7 3 5
niko 2 -1 3 6 4
tin nan 5 5 6 7
预期结果是(拉里:1次,尼科:2次,锡:3次)
times_of_top day1 day2 day3 day4 day5
larry 1 1 4 7 3 5
niko 2 2 -1 3 6 4
tin 3 nan 5 5 6 7
niko
在day1
和day4
上得分最高,所以他的times_of_top
是2。tin
在{
使用
pandas.DataFrame.stack
和count
的一种方法:输出:
相关问题 更多 >
编程相关推荐