首页 > 其他 > 详细

[问题解决]pandas DataFrame中经常出现SettingWithCopyWarning

时间:2018-11-08 17:28:13      阅读:636      评论:0      收藏:0      [点我收藏+]

先从原dataframe取出一个子dataframe,然后再对其中的元素赋值,例如

s = d[d['col_1'] == 0]
s.loc[:, 'col_2'] = 1

就会出现报错:
SettingWithCopyWarning: A value is trying to be set on a copy of a slice from a DataFrame.
Try using .loc[row_indexer,col_indexer] = value instead
解决方法:

  1. 使用推荐的 .loc[row_indexer,col_indexer] = value
  2. 如果不知道,就先copy,再赋值。
s = d[d['col_1'] == 0].copy()
s.loc[:, 'col_2'] = 1

[问题解决]pandas DataFrame中经常出现SettingWithCopyWarning

原文:https://www.cnblogs.com/everfight/p/SettingWithCopyWarning.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!