pandas DataFrame 警告(SettingWithCopyWarning)的解決
剛接觸python不久,編程也是三腳貓,所以對(duì)常用的這幾個(gè)工具還沒(méi)有一個(gè)好的使用習(xí)慣,畢竟程序語(yǔ)言是頭順毛驢。所以最近在工作中使用的時(shí)候在使用pandas的DataFrame時(shí)遇到了以下報(bào)警:
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了半天,也在網(wǎng)上找了很多,還是沒(méi)有解決,在報(bào)警的那一句調(diào)了半天,后來(lái)發(fā)現(xiàn)主要問(wèn)題并不是出現(xiàn)在報(bào)警的那一句。
給個(gè)例子復(fù)現(xiàn)一下這個(gè)問(wèn)題:
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
先說(shuō)一下我的感覺(jué):這個(gè)報(bào)警主要是說(shuō),你當(dāng)前對(duì)B的操作可能會(huì)改變另一個(gè)DataFrame A,所以你要小心了。(當(dāng)然實(shí)際的警告并不是這個(gè)意思,但是“在DataFrame的一個(gè)切片的copy上進(jìn)行操作”我感覺(jué)不出來(lái)有什么問(wèn)題,還請(qǐng)大神們解答一下。)
報(bào)警出現(xiàn)在第4行,但主要的問(wèn)題在于第3行:應(yīng)該使用.loc方法得到新的DataFrame,而不是直接使用[]引用。
C = A.loc[:,['a','b']] C['a'] = C['a']+1
這樣就不會(huì)出現(xiàn)報(bào)警了。
個(gè)人感覺(jué)好像是說(shuō)用.loc是對(duì)原有DataFrame的一種復(fù)制性引用,而[]的引用則是指針性的引用,和python本身的賦值特性有關(guān)。不過(guò)我看了A的值也并沒(méi)有在B被更改時(shí)一同被改掉??傊椰F(xiàn)在還只是知其然,不知其所以然,希望有大神幫忙解惑。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python3使用迭代生成器實(shí)現(xiàn)減少內(nèi)存占用
這篇文章主要介紹了python3使用迭代生成器實(shí)現(xiàn)減少內(nèi)存占用的相關(guān)資料,需要的朋友可以參考下2021-05-05Python人工智能深度學(xué)習(xí)RNN模型結(jié)構(gòu)流程
這篇文章主要為大家介紹了Python人工智能深度學(xué)習(xí)RNN的模型流程結(jié)構(gòu),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-11-11request基本使用及各種請(qǐng)求方式參數(shù)的示例
這篇文章主要為大家介紹了request的基本使用及各種請(qǐng)求方式參數(shù)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04通用的Django注冊(cè)功能模塊實(shí)現(xiàn)方法
這篇文章主要介紹了通用的Django注冊(cè)功能模塊實(shí)現(xiàn)步驟,幫助大家更好的理解和使用django,感興趣的朋友可以了解下2021-02-02python神經(jīng)網(wǎng)絡(luò)MobileNetV3?large模型的復(fù)現(xiàn)詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)MobileNetV3?large模型的復(fù)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05python超詳細(xì)實(shí)現(xiàn)完整學(xué)生成績(jī)管理系統(tǒng)
讀萬(wàn)卷書(shū)不如行萬(wàn)里路,只學(xué)書(shū)上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用Java實(shí)現(xiàn)一個(gè)完整版學(xué)生成績(jī)管理系統(tǒng),大家可以在過(guò)程中查缺補(bǔ)漏,提升水平2022-03-03Python圖像處理之直線和曲線的擬合與繪制【curve_fit()應(yīng)用】
這篇文章主要介紹了Python圖像處理之直線和曲線的擬合與繪制,結(jié)合實(shí)例形式分析了Python曲線擬合相關(guān)函數(shù)curve_fit()的使用技巧,需要的朋友可以參考下2018-12-12