Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Mengendalikan Tetapan Pandas Dengan Berkesan DenganCopyWarning?

Bagaimanakah Saya Boleh Mengendalikan Tetapan Pandas Dengan Berkesan DenganCopyWarning?

Linda Hamilton
Linda Hamiltonasal
2024-12-25 15:02:12140semak imbas

How Can I Effectively Handle Pandas' SettingWithCopyWarning?

Mengendalikan SettingWithCopyWarning dalam Panda

Semasa menaik taraf Panda daripada 0.11 kepada 0.13.0rc1, pengguna mungkin menghadapi banyak mesej SettingWithCopyWarning. Satu contoh sedemikian ialah:

E:\FinReporter\FM_EXT.py:449: SettingWithCopyWarning: A value is trying to be set on a copy of a slice from a DataFrame.
Try using .loc[row_index,col_indexer] = value instead
quote_df['TVol']   = quote_df['TVol']/TVOL_SCALE

Memahami Amaran

SettingWithCopyWarning menandakan tugasan "berantai" yang berpotensi mengelirukan seperti:

df[df['A'] > 2]['B'] = new_val  # new_val not set in df

Ini tidak selalu berfungsi sebagai dijangka, terutamanya apabila pilihan pertama mengembalikan salinan. Untuk menyelesaikan isu ini, gunakan:

df.loc[df['A'] > 2, 'B'] = new_val

Menangani Amaran dalam Kod yang Diberikan

Dalam coretan kod yang disediakan:

quote_df['TVol']   = quote_df['TVol']/TVOL_SCALE

anda sedang melaksanakan a tugasan berantai bersamaan dengan:

quote_df = quote_df[quote_df['A'] > 2]
quote_df['TVol'] = new_val

Corak ini tidak boleh dibezakan daripada contoh negatif dan mencetuskan amaran.

Melumpuhkan Amaran

Jika anda yakin tulisan tidak akan menjejaskan bingkai asal, lumpuhkan amaran dengan:

import pandas as pd
pd.options.mode.chained_assignment = None  # default='warn'

Maklumat Tambahan

Untuk pemahaman lanjut, rujuk sumber ini:

  • Pengguna Pandas Panduan: Mengindeks dan memilih data
  • Buku Panduan Sains Data Python: Pengindeksan dan Pemilihan Data
  • Real Python: SettingWithCopyWarning dalam Panda
  • Dataquest: SettingwithCopyWarning: Cara Membetulkan Amaran Ini dalam Pandas
  • Ke Arah Sains Data: Menjelaskan SettingWithCopyWarning dalam panda

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengendalikan Tetapan Pandas Dengan Berkesan DenganCopyWarning?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn