[pandas] SettingWithCopyWarning: A value is trying to be set on a copy of a slice from a DataFrame


轉載自https://blog.csdn.net/blackyuanc/article/details/77892784

問題場景:

      在讀取CSV文件后,在新增一個特征列並根據已有特征修改新增列的值,結果在修改的過程中碰到SettingWithCopyWarning警告。

報錯的做法

  1 import pandas as pd
  2 import numpy as np
  3 
  4 aa = np.array([1,0,1,0])
  5 bb = pd.DataFrame(aa.T, columns=['one'])
  6 
  7 bb['two'] = 0
  8 
  9 for i in range(bb.shape[0]):
 10         bb['two'][i] = 1
 11 
 12 print(bb)

正確的做法:

  1 # -*- coding: utf-8 -*-
  2 import pandas as pd
  3 import numpy as np
  4 
  5 aa = np.array([1,0,1,0])
  6 bb = pd.DataFrame(aa.T, columns=['one'])
  7 
  8 # 建立
  9 two = np.zeros(bb.shape[0])
 10 
 11 # 修改
 12 for i in range(bb.shape[0]):
 13     two[i] = random.random()
 14 
 15 # 插入
 16 bb.insert(0,'two',two)
 17 
 18 print(bb)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM