[英]Multiply top h values times k for each row in a dataframe python
我有一个数据框,其中一些日期为列中的行和值。 要知道df如下所示:
c1 c2 c3 c4
12/12/2016 38 10 1 8
12/11/2016 44 12 17 46
12/10/2016 13 6 2 7
12/09/2016 9 16 13 26
我试图找到一种迭代每一行的方法,并且只将前2个值乘以k = 3.结果应该在现有df的新列中。 任何建议或提示都非常感谢!
谢谢!
在groupby
+ nlargest
之后使用update
df.update(df.stack().groupby(level=0).nlargest(2).mul(k).reset_index(level=0,drop=True).unstack())
df
Out[1036]:
c1 c2 c3 c4
12/12/2016 114.0 30.0 1 8.0
12/11/2016 132.0 12.0 17 138.0
12/10/2016 39.0 6.0 2 21.0
12/09/2016 9.0 48.0 13 78.0
nlargest
df.assign(newcol=df.apply(sorted, 1).iloc[:, -2:].sum(1) * 3)
c1 c2 c3 c4 newcol
12/12/2016 38 10 1 8 144
12/11/2016 44 12 17 46 270
12/10/2016 13 6 2 7 60
12/09/2016 9 16 13 26 126
partition
df.assign(newcol=np.partition(df, -2)[:, -2:].sum(1) * 3)
c1 c2 c3 c4 newcol
12/12/2016 38 10 1 8 144
12/11/2016 44 12 17 46 270
12/10/2016 13 6 2 7 60
12/09/2016 9 16 13 26 126
使用df.where
+ df.rank
n = 2
k = 3
df.where(df.rank(1, method='dense') <= len(df.columns)-n, df*k)
c1 c2 c3 c4
12/12/2016 114 30 1 8
12/11/2016 132 12 17 138
12/10/2016 39 6 2 21
12/09/2016 9 48 13 78
为了解决您的更新,您仍然可以使用where + rank,尽管它似乎不适合上述操作。
df['new_col'] = df.where(df.rank(1, method='dense') >= len(df.columns)-n, df*0).sum(1)*k
c1 c2 c3 c4 new_col
12/12/2016 38 10 1 8 144
12/11/2016 44 12 17 46 270
12/10/2016 13 6 2 7 60
12/09/2016 9 16 13 26 126
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.