dataframe 根据条件查找_python – 在Pandas DataFrame中查找第一列匹配条件的矢量化方法...

假设我有以下pandas DataFrame:

A B C

0 0.548814 0.791725 0.978618

1 0.715189 0.528895 0.799159

2 0.602763 0.568045 0.461479

3 0.544883 0.925597 0.780529

4 0.423655 0.071036 0.118274

5 0.645894 0.087129 0.639921

6 0.437587 0.020218 0.143353

7 0.891773 0.832620 0.944669

8 0.963663 0.778157 0.521848

9 0.383442 0.870012 0.414662

可以使用以下代码创建:

import pandas as pd

import numpy as np

size = 10

np.random.seed(0)

keys = ["A", "B", "C"]

df = pd.DataFrame({k: np.random.random(size) for k in keys})

如何找到符合给定条件的第一列?

在这种情况下,假设我的标准是我想要第一列,其中值小于某个p,比如0.5.如果没有列符合此条件,我想返回“不匹配”.

使用apply,这可以做到如下:

p = 0.5

first = df.apply(

lambda row: next((x for i, x in enumerate(df.columns) if row[x]

axis

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值