首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >逐行迭代时更新pandas中的dataframe

逐行迭代时更新pandas中的dataframe
EN

Stack Overflow用户
提问于 2014-04-28 08:19:50
回答 6查看 360.7K关注 0票数 287

我有一个熊猫数据框,看起来像这样(它很大)

代码语言:javascript
复制
           date      exer exp     ifor         mat  
1092  2014-03-17  American   M  528.205  2014-04-19 
1093  2014-03-17  American   M  528.205  2014-04-19 
1094  2014-03-17  American   M  528.205  2014-04-19 
1095  2014-03-17  American   M  528.205  2014-04-19    
1096  2014-03-17  American   M  528.205  2014-05-17 

现在我想逐行迭代,当我遍历每一行时,每一行中ifor的值可能会根据某些条件而变化,我需要查找另一个数据帧。

现在,我如何在迭代时更新它。试了几次都没成功。

代码语言:javascript
复制
for i, row in df.iterrows():
    if <something>:
        row['ifor'] = x
    else:
        row['ifor'] = y

    df.ix[i]['ifor'] = x

这些方法似乎都行不通。我没有在数据框中看到更新的值。

EN

回答 6

Stack Overflow用户

发布于 2017-12-02 11:37:20

您可以使用的一种方法是itertuples(),它将DataFrame行作为命名元组进行迭代,索引值作为元组的第一个元素。而且与iterrows()相比,它的速度要快得多。对于itertuples(),每个row在DataFrame中都包含它的Index,您可以使用loc来设置该值。

代码语言:javascript
复制
for row in df.itertuples():
    if <something>:
        df.at[row.Index, 'ifor'] = x
    else:
        df.at[row.Index, 'ifor'] = x

    df.loc[row.Index, 'ifor'] = x

在大多数情况下,itertuples()iatat更快。

感谢@SantiStSupery,using .at is much faster than loc

票数 58
EN

Stack Overflow用户

发布于 2014-04-28 10:36:52

您应该使用df.ix[i, 'exp']=Xdf.loc[i, 'exp']=X而不是df.ix[i]['ifor'] = x来赋值。

否则,您正在处理一个视图,并且应该会得到一个预热:

-c:1: SettingWithCopyWarning: A value is trying to be set on a copy of a slice from a DataFrame. Try using .loc[row_index,col_indexer] = value instead

但可以肯定的是,循环可能更好地被一些矢量化算法取代,以充分利用DataFrame,就像@Phillip Cloud建议的那样。

票数 23
EN

Stack Overflow用户

发布于 2020-06-01 04:28:18

最好使用带有df.apply()lambda函数-

代码语言:javascript
复制
df["ifor"] = df.apply(lambda x: {value} if {condition} else x["ifor"], axis=1)
票数 19
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23330654

复制
相关文章

相似问题

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