胡樟子 2021-05-29 05:33 采纳率: 100%
浏览 25
已结题

如何将Dataframe一列中的三值快速变为二值?

某列有三种可能的取值:1,0,-1,要求将0替换为其前非0的数值。

例如,对于pd.DataFrame({'A':[1,-1,0,0,1,0,-1]})的转换结果为:1,-1,-1,-1,1,1,-1。

我用iloc遍历的方法可以解决,但是速度极慢,请教有没有高效的答案。

  • 写回答

2条回答 默认 最新

  • Shepherdppz 2021-12-15 11:18
    关注

    我的思路是先将所有0替换成NAN值,然后再用pandas.fillna()函数处理前向填充——该函数有一个“frill”参数,可以用前一个值填充NAN值,这几个函数都是批量执行的速度很快,应该能实现您要的效果

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月23日
  • 已采纳回答 12月15日

悬赏问题

  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码