如何解决使用基于两列的if条件更新数据框
我有一个学生数据框,并且想要将通行列值更新为失败,而学生姓名为Tom且年龄为10。由于我是编程新手。有人可以建议我这段代码有什么问题吗?它不起作用。
import pandas as pd
data = [['tom',10,'True'],['nick',15,['juli',14,'True']]
df = pd.DataFrame(data,columns = ['Name','Age','Pass'])
df
def result(df):
if(df['Name']=='tom') and (df['Age']==10)):
return 'Fail'
df2['Passs']=df2.apply(result,axis=1)
解决方法
尝试一下
df.loc[df.Name.eq('tom') & df.Age.eq(10),'Pass'] = 'Fail'
print(df)
输出:
Name Age Pass
0 tom 10 Fail
1 nick 15 True
2 juli 14 True
,
import pandas as pd
data = [['tom',10,'True'],['nick',15,['juli',14,'True']]
df = pd.DataFrame(data,columns = ['Name','Age','Pass'])
def myfunc(row):
if (row.Name == 'tom') and( row.Age == 10) :
return "Fail"
else:
return row.Pass
df.loc[:,'Pass'] = df.apply(myfunc,axis = 1)
print(df)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。