Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Menggantikan Nilai dalam Lajur DataFrame Berdasarkan Syarat?
Menggantikan Nilai dalam Lajur DataFrame Berdasarkan Keadaan
Dalam senario ini, anda mempunyai DataFrame dengan lajur bernama 'Musim Pertama'. Anda ingin mengubah suai nilai dalam lajur ini, khususnya menggantikan nilai yang lebih tinggi daripada 1990 dengan nilai 1. Walaupun percubaan yang dibuat adalah untuk memilih nilai menggunakan df.loc[(df['Musim Pertama'] > 1990)] = 1, ia menggantikan semua nilai dalam baris yang dipilih dan bukannya hanya menyasarkan lajur 'Musim Pertama'.
Untuk menggantikan nilai secara berkesan dalam lajur tertentu berdasarkan syarat, adalah penting untuk menyatakan dengan jelas lajur dalam kriteria pemilihan . Ini dicapai menggunakan sintaks berikut:
<code class="python">df.loc[<mask>, <optional column(s)>]</code>
Dalam kes anda, topeng digunakan untuk memilih baris dengan nilai 'Musim Pertama' lebih besar daripada 1990. Kod di bawah akan mencapai hasil yang diingini:
<code class="python">df.loc[df['First Season'] > 1990, 'First Season'] = 1</code>
Sebagai alternatif, jika anda berhasrat untuk mencipta penunjuk boolean, anda boleh menggunakan syarat boolean untuk menjana Siri boolean dan menukar nilai Benar dan Salah kepada integer menggunakan .astype(). Pendekatan ini akan menghasilkan lajur dengan nilai 1 (Benar) dan 0 (Salah).
<code class="python">df['First Season'] = (df['First Season'] > 1990).astype(int)</code>
Atas ialah kandungan terperinci Bagaimana untuk Menggantikan Nilai dalam Lajur DataFrame Berdasarkan Syarat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!