首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何处理SettingWithCopyWarning:

如何处理SettingWithCopyWarning:
EN

Stack Overflow用户
提问于 2018-04-07 12:57:31
回答 2查看 180关注 0票数 1

我正在使用ipython3 notebook并运行以下命令:

代码语言:javascript
运行
复制
separ['RT'] = separ['text'].str.contains(r"^(?=.*\bRT\b\s@\b).*$", 
case=False) == True

我得到的警告如下:

代码语言:javascript
运行
复制
-c:3: 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

我不知道这是什么意思,也不知道该如何处理。

EN

Stack Overflow用户

发布于 2018-04-07 13:34:07

问题出在过滤上:

代码语言:javascript
运行
复制
separ = tweets[tweets['TradeWar'] == True] 

什么与以下内容相同:

代码语言:javascript
运行
复制
separ = tweets[tweets['TradeWar']]

并且需要copy

代码语言:javascript
运行
复制
separ = tweets[tweets['TradeWar']].copy()

如果您稍后修改separ中的值,您会发现修改不会传播回原始数据(tweets),并且Pandas会发出警告。

同样,代码也应该简化:

代码语言:javascript
运行
复制
separ['RT'] = separ['text'].str.contains(r"^(?=.*\bRT\b\s@\b).*$", case=False) 
票数 0
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49704000

复制
相关文章

相似问题

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