如果满足 for 循环中的条件,则在同一行中的其他单元格中获取值

Posted

技术标签:

【中文标题】如果满足 for 循环中的条件,则在同一行中的其他单元格中获取值【英文标题】:Get value in other cell in same row when if condition in for loop is met 【发布时间】:2021-09-30 17:29:15 【问题描述】:

我想遍历数据框列,当达到特定值时,我想将值保存在我创建的另一列中,并在同一行中称为“索引”。这是一个例子df:

index  value
  0      a
  2      b
  3      c
  9      a
  23     d

我尝试这样编写代码:

for value in df["value"]:
    if value == "a":
       current_index = #get value in "index" in current row

我不能简单地保存值为“a”的行的所有索引,因为那时我的其余代码将无法工作。

我认为这应该很容易,但不知何故我找不到解决方案。

感谢大家的支持!

【问题讨论】:

【参考方案1】:

IIUC:

尝试通过布尔掩码和 loc 访问器:

out=df.loc[df['value'].eq('a'),'index'].tolist()

out的输出:

[0, 9]

如果你想创建一个列,那么:

df['newcol']=df['index'].where(df['value'].eq('a'))

df的输出:

    index   value   newcol
0   0       a       0.0
1   2       b       NaN
2   3       c       NaN
3   9       a       9.0
4   23      d       NaN

【讨论】:

以上是关于如果满足 for 循环中的条件,则在同一行中的其他单元格中获取值的主要内容,如果未能解决你的问题,请参考以下文章

如果满足条件,则移动到嵌套 for 循环中的下一次迭代

如果if条件满足,如何跳转到for循环中的特定位置?

如果在 R 中满足条件,则从前一行获取值并连接

js中的语句讲解 (条件语句和for循环语句)

java中的for循环

浅谈python中的while循环