pandas DataFrame 警告(SettingWithCopyWarning)的解决


Posted in Python onJuly 23, 2019

刚接触python不久,编程也是三脚猫,所以对常用的这几个工具还没有一个好的使用习惯,毕竟程序语言是头顺毛驴。所以最近在工作中使用的时候在使用pandas的DataFrame时遇到了以下报警:

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
See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy

debug了半天,也在网上找了很多,还是没有解决,在报警的那一句调了半天,后来发现主要问题并不是出现在报警的那一句。

给个例子复现一下这个问题:

import pandas as pd
A = pd.DataFrame([[1,2,3],[2,3,4],[3,4,5]], columns = ['a','b','c'])
B = A[['a', 'b']]
B['a'] = B['a'] + 1 # same result by using B.loc[:,'a'] = B.loc[:,'a']+ 1

输出:

A
Out[1]:
   a  b  c
0  1  2  3
1  2  3  4
2  3  4  5

B
Out[2]:
   a  b
0  1  2
1  2  3
2  3  4

B
Out[3]:
   a  b
0  2  2
1  3  3
2  4  4

先说一下我的感觉:这个报警主要是说,你当前对B的操作可能会改变另一个DataFrame A,所以你要小心了。(当然实际的警告并不是这个意思,但是“在DataFrame的一个切片的copy上进行操作”我感觉不出来有什么问题,还请大神们解答一下。)

报警出现在第4行,但主要的问题在于第3行:应该使用.loc方法得到新的DataFrame,而不是直接使用[]引用。

C = A.loc[:,['a','b']]
C['a'] = C['a']+1

这样就不会出现报警了。

个人感觉好像是说用.loc是对原有DataFrame的一种复制性引用,而[]的引用则是指针性的引用,和python本身的赋值特性有关。不过我看了A的值也并没有在B被更改时一同被改掉。总之我现在还只是知其然,不知其所以然,希望有大神帮忙解惑。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
推荐下python/ironpython:从入门到精通
Oct 02 Python
python元组操作实例解析
Sep 23 Python
Python调用ctypes使用C函数printf的方法
Aug 23 Python
Python实现控制台中的进度条功能代码
Dec 22 Python
python实现外卖信息管理系统
Jan 11 Python
使用Python的SymPy库解决数学运算问题的方法
Mar 27 Python
python Elasticsearch索引建立和数据的上传详解
Aug 04 Python
Django1.11配合uni-app发起微信支付的实现
Oct 12 Python
Python中实现输入一个整数的案例
May 03 Python
15款Python编辑器的优缺点,别再问我“选什么编辑器”啦
Oct 19 Python
python 模块导入问题汇总
Feb 01 Python
浅谈Python3中datetime不同时区转换介绍与踩坑
Aug 02 Python
利用Python库Scapy解析pcap文件的方法
Jul 23 #Python
python3.x提取中文的正则表达式示例代码
Jul 23 #Python
Python Pandas 箱线图的实现
Jul 23 #Python
Django 开发调试工具 Django-debug-toolbar使用详解
Jul 23 #Python
Pandas分组与排序的实现
Jul 23 #Python
Python项目 基于Scapy实现SYN泛洪攻击的方法
Jul 23 #Python
Django logging配置及使用详解
Jul 23 #Python
You might like
php mysql数据库操作分页类
2008/06/04 PHP
PHP+Ajax异步通讯实现用户名邮箱验证是否已注册( 2种方法实现)
2011/12/28 PHP
phpMyAdmin 链接表的附加功能尚未激活问题的解决方法(已测)
2012/03/27 PHP
php发送post请求函数分享
2014/03/06 PHP
非常好的js代码
2006/06/27 Javascript
jquery.boxy插件的iframe扩展代码
2010/07/02 Javascript
jquery选择器原理介绍($()使用方法)
2014/03/25 Javascript
JS判断客服QQ号在线还是离线状态的方法
2015/01/13 Javascript
JQuery选择器、过滤器大整理
2015/05/26 Javascript
动态加载jQuery的方法
2015/06/16 Javascript
jquery+css3实现会动的小圆圈效果
2016/01/27 Javascript
通过原生JS实现为元素添加事件的方法
2016/11/23 Javascript
jQuery Validate验证框架详解(推荐)
2016/12/17 Javascript
微信小程序用户自定义模版用法实例分析
2017/11/28 Javascript
解决vuex改变了state的值,但是页面没有更新的问题
2020/11/12 Javascript
Python数据类型详解(四)字典:dict
2016/05/12 Python
Python编程把二叉树打印成多行代码
2018/01/04 Python
Python设计模式之命令模式简单示例
2018/01/10 Python
Numpy之random函数使用学习
2019/01/29 Python
python把ipynb文件转换成pdf文件过程详解
2019/07/09 Python
Python接口自动化判断元素原理解析
2020/02/24 Python
使用opencv中匹配点对的坐标提取方式
2020/06/04 Python
django 将自带的数据库sqlite3改成mysql实例
2020/07/09 Python
python实现简单的学生管理系统
2021/02/22 Python
简述数据库的设计过程
2015/06/22 面试题
读书心得体会
2013/12/28 职场文书
车间统计员岗位职责
2014/01/05 职场文书
测试工程师程序员求职信范文
2014/02/20 职场文书
项目合作协议书
2014/04/16 职场文书
广告学专业毕业生自荐信
2014/05/28 职场文书
学校学雷锋活动总结
2014/06/26 职场文书
物流管理专业推荐信
2014/09/06 职场文书
个人廉洁自律总结
2015/03/06 职场文书
Python 制作自动化翻译工具
2021/04/25 Python
Java并发编程必备之Future机制
2021/06/30 Java/Android
Python之matplotlib绘制饼图
2022/04/13 Python