找出每一行第一个不为零的列名

练习题目

1、找出每一行第一个不为零的列名添加到最后一列,没有找到则把空添加到最后一列。用python解决。

  • 遍历每一行找到不为零的下标
  • 根据下标获取列名
  • 为datafame增加一列
# pip install pandas numpy   -i http://pypi.douban.com/simple --trusted-host pypi.douban.com

import pandas as pd


def find(line):
    for i, v in enumerate(line):
        if v > 0:
            return line.index[i]
    return ""


def repair_data(data):
    a = []
    for index, row in data.iterrows():
        a.append(find(row))
    data['rs'] = a
    return data


if __name__ == '__main__':
    inp = [{'c1': 10, 'c2': 100}, {'c1': 0, 'c2': 1}, {'c1': 0, 'c2': 0}, {'c1': 12, 'c2': 0}]
    df = pd.DataFrame(inp)
    print(repair_data(df))

运行结果如下:

在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值