首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在DataFrame列之间执行逻辑操作?

如何在DataFrame列之间执行逻辑操作?
EN

Stack Overflow用户
提问于 2017-04-28 07:53:32
回答 1查看 87关注 0票数 1
代码语言:javascript
运行
复制
import pandas as pd
data = [{'a': 1, 'b': 2, 'valid': True}, {'a': 3, 'b': 4, 'valid':False}]
df = pd.DataFrame(data)

   a  b  valid
0  1  2   True
1  3  4  False

如果a为True,则将valid列数据分配给新列;如果valid为False,则将b列数据分配给新列。有人能告诉我怎么做吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-04-28 07:55:50

您可以使用numpy.where

代码语言:javascript
运行
复制
df['new'] = np.where(df['valid'], df['a'], df['b'])
print (df)
   a  b  valid  new
0  1  2   True    1
1  3  4  False    4
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43674956

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档