您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關pandas中DataFrame出現警告SettingWithCopyWarning怎么辦,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
在工作中使用的時候在使用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 5B
Out[2]:
a b
0 1 2
1 2 3
2 3 4B
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
這樣就不會出現報警了。
關于“pandas中DataFrame出現警告SettingWithCopyWarning怎么辦”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。