python - Groupby 数据框从每个组成员中获取非空元素
问题描述
我有一个数据框,在某些情况下,一个案例的记录不止一行,某些行中有空值,如下所示:
date_rounded 1 2 3 4 5
0 2020-04-01 00:05:00 0.0 NaN NaN NaN NaN
1 2020-04-01 00:05:00 NaN 1.0 44.0 44.0 46.454
2 2020-04-01 00:05:00 NaN NaN NaN NaN NaN
我只想有一行填充数据,到目前为止我有:
df.groupby(['date_rounded']).apply(lambda df0: df0.fillna(method='ffill').fillna(method='bfill').drop_duplicates())
这行得通,但是速度很慢,有更好的主意吗?
谢谢
解决方案
您还可以使用groupby
and first
:
df.groupby("date_rounded").first()
1 2 3 4 5
date_rounded
2020-04-01 00:05:00 0.0 1.0 44.0 44.0 46.454
推荐阅读
- javascript - 函数在 Promise.all(reduce(acc, item) => {})) 函数中丢失上下文
- python - 为什么所有双下划线变量都在类方法中被破坏
- swift - 如何从字符串中间删除一个字符?斯威夫特 4
- jboss - 为什么 Jboss 7.2 用域而不是相对路径覆盖 HTML 表单操作路径?
- javascript - Javascript:球体碰撞和产生的脉冲
- r - 具有不同颜色点的散点图
- python - Pandas:对于 2 个或更多特定列值完全相同的行组,如何将唯一整数分配为新列
- ruby - logstash 拆分路径并通过其位置 [2] 获取某个值并将其插入到字段中
- swift - SwiftUI 中的 firstIndex 是什么 - Swift
- python-3.x - 通过套接字发送文件时出现问题“在'int'和''字节'的实例之间不支持''