【发布时间】:2016-02-19 11:37:10
【问题描述】:
如何将数据框给定列的每个元素与标量相乘? (我尝试过查看 SO,但似乎找不到正确的解决方案)
做类似的事情:
df['quantity'] *= -1 # trying to multiply each row's quantity column with -1
给我一个警告:
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
注意:如果可能的话,我不想遍历数据帧并做这样的事情......因为我认为整个列上的任何标准数学运算都应该是可能的,而无需编写循环:
for idx, row in df.iterrows():
df.loc[idx, 'quantity'] *= -1
编辑:
我正在运行 0.16.2 的 Pandas
完整的跟踪:
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 the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy
self.obj[item] = s
【问题讨论】:
-
使用
dtype检查该列的类型。我无法复制该错误,最好提供完整的回溯。 -
我已经编辑以添加完整的跟踪...这也不是错误,它是警告(为了清楚起见)
-
我认为它是由该行以外的其他原因引起的,或者该行可能导致之前生成的警告上升。您得到的与切片数据框有关。
-
很好奇,你有想过这个吗?我正在处理同样的问题。
-
在这段代码之前的某个时刻,您已经过滤了 df 以减少行数或其他东西。也许你做了
df = BigDF.query("X == 1")或df = BigDF[BigDF.X == 1]或类似的东西,这意味着 df 实际上只是 BigDF 的一个视图。警告告诉您它正在强制它进行复制,否则会导致 BigDF 发生变化。
标签: python pandas chained-assignment