python使用dataframe报错SettingWithCopyWarning(保姆级图文+代码注释)

本文介绍了在使用Pandas DataFrame时遇到的SettingWithCopyWarning警告,这是由于尝试在数据帧副本上设置值导致的。文章通过一个实例展示了错误的修改方式(直接索引修改会引发警告)和正确的修改方式(使用loc或iloc)。作者建议使用loc或iloc遍历数组以避免此类警告。
摘要由CSDN通过智能技术生成

系列文章

提示:转到python专栏,观看更多内容!
点我直达–>python专栏


前言

使用Pandas-DataFrame修改DataFrame数组的某个值时出现SettingWithCopyWarning报错
具体如下:

SettingWithCopyWarning: 
A value is trying to be set on a copy of a slice from a DataFrame
See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy

原因分析:使用CopyWarning设置:试图在数据帧切片的副本上设置值请参阅文档中的注意事项。
涉及了Pandas-DataFrame的底层架构,网上也有大佬深度分析,作为初学者我就长话短说,说说怎么修改DataFrame数组的某个值不报错的方法。

就是不能直接用列表名索引的方式访问数据并修改,必须用loc遍历数组的方式修改!


1.新建一个测试用的DataFrame

import pandas as pd
data = {
    'id':['a','b','c','d','e'],
    'name':[1,2,3,4,5],
    'score':[x for x in range(6,11)]#生成一个6-10的列表,左开右闭
}
frame = pd.DataFrame(data)
# 输出效果
#   id  name  score
# 0  a     1      6
# 1  b     2      7
# 2  c     3      8
# 3  d     4      9
# 4  e     5     10

在这里插入图片描述


2.测试错误的修改方式(会报错)

print("测试错误的修改方式,测试时注释下一段代码")
print(frame['id'][0])#打印了 id列的第0位元素-> a
frame_new=frame.copy()
frame_new['id'][0]='q'#错误的修改 id列的第0位元素为q,报错SettingWithCopyWarning
print(frame_new)

在这里插入图片描述

3.测试正确的修改方式

核心区别是不能直接用列表名索引的方式访问数据并修改,必须用loc遍历数组的方式修改!

print("测试正确的修改方式,测试时注释上一段代码")
print(frame.loc[0][0])#打印了 id列的第0位元素-> a
frame_new=frame.copy()
frame_new.iloc[0,0]="q" #正确的修改 id列的第0位元素为q,不会报错
print(frame_new)

在这里插入图片描述

4.完整代码

# @Time    : 2021/12/8 8:50
# @Author  : 南黎
# @FileName: test.py
import pandas as pd

print("新建一个测试用的DataFrame")
data = {
    'id':['a','b','c','d','e'],
    'name':[1,2,3,4,5],
    'score':[x for x in range(6,11)]#生成一个6-10的列表,左开右闭
}
frame = pd.DataFrame(data)
# 输出效果
#   id  name  score
# 0  a     1      6
# 1  b     2      7
# 2  c     3      8
# 3  d     4      9
# 4  e     5     10

print("测试错误的修改方式,测试时注释下一段代码")
print(frame['id'][0])#打印了 id列的第0位元素-> a
frame_new=frame.copy()
frame_new['id'][0]='q'#错误的修改 id列的第0位元素为q,报错SettingWithCopyWarning
print(frame_new)

print("测试正确的修改方式,测试时注释上一段代码")
print(frame.loc[0][0])#打印了 id列的第0位元素-> a
frame_new=frame.copy()
frame_new.iloc[0,0]="q" #正确的修改 id列的第0位元素为q,不会报错
print(frame_new)


总结

大家喜欢的话,给个👍,点个关注!继续跟大家分享敲代码过程中遇到的问题!


评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

发现你走远了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值