【发布时间】:2021-03-05 18:09:53
【问题描述】:
我有一个 Pandas DataFrame,我想使用以下代码更改列的所有值:
df["Population"] = round(df["Population"]/1000000,1)
我收到以下警告:
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
return super().rename(
<ipython-input-6-59bf041bb022>:2: 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: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy
df["Population"] = round(df["Population"]/1000000,1)
什么是正确的方法来避免这种警告?
感谢您的帮助!
【问题讨论】: