python - 警告 - 试图在切片的副本上设置值

标签 python python-3.x pandas dataframe

当我运行此代码时,我收到警告。我尝试了我能想到的所有可能的解决方案,但无法摆脱它。请帮忙!

尝试在 DataFrame 的切片副本上设置值。 尝试使用 .loc[row_indexer,col_indexer] = value 代替

import math
task2_df['price_square'] = None
i = 0
for row in data.iterrows():
    task2_df['price_square'].at[i] = math.pow(task2_df['price'][i],2)
    i += 1

最佳答案

对于初学者,我在 Pandas v0.19.2 上没有看到您的错误(使用本答案底部的代码进行测试)。但这可能与解决您的问题无关。您应该避免在Python 级循环中迭代行。 Pandas 使用的 NumPy 数组是专门为数值计算而设计的:

df = pd.DataFrame({'price': [54.74, 12.34, 35.45, 51.31]})
df['price_square'] = df['price'].pow(2)

print(df)

   price  price_square
0  54.74     2996.4676
1  12.34      152.2756
2  35.45     1256.7025
3  51.31     2632.7161

在 Pandas v0.19.2 上进行测试,没有警告/错误:

import math

df = pd.DataFrame({'price': [54.74, 12.34, 35.45, 51.31]})
df['price_square'] = None
i = 0

for row in df.iterrows():
    df['price_square'].at[i] = math.pow(df['price'][i],2)
    i += 1

关于python - 警告 - 试图在切片的副本上设置值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53004973/

相关文章:

python - Django:用很少的字段实例初始化表单

python - sqlalchemy + pymssql 连接失败

python-3.x - 如何使用 Python(Boto lib)获取 Amazon S3 存储桶的大小?

python - Pandas 删除重复的数据范围

python - 返回包含字符串列中存在的关键字列表的列 - Pandas

python - 是否有像 numpy.clip(a, a_min, a_max) 这样的函数,其中 a_min 和 a_max 之外的值被包裹而不是饱和?

python - 如何访问上传的json文件google colab

python - PyPDF2 复制后返回空白 PDF

相当于 MATLAB spones 的 numpy

python - 将方法列表中的方法应用到 Pandas 数据框