Rumah > pembangunan bahagian belakang > Tutorial Python > Bagaimanakah saya Boleh Memusingkan Pandas DataFrame dengan Berkesan?

Bagaimanakah saya Boleh Memusingkan Pandas DataFrame dengan Berkesan?

Barbara Streisand
Lepaskan: 2024-12-27 15:43:11
asal
292 orang telah melayarinya

How Can I Effectively Pivot a Pandas DataFrame?

Bagaimanakah saya boleh memaksi bingkai data?

Pangsi ialah transformasi yang mengambil bingkai data dengan lajur mewakili kategori dan baris mewakili nilai, dan mengorientasikan semula supaya kategori berada dalam baris, nilai berada dalam lajur dan indeks ditetapkan kepada baris asal nilai.

Sintaks asas:

df.pivot(index=<row_labels>, columns=<col_labels>, values=<value_cols>)
Salin selepas log masuk

Contoh:

  • Pivot pada satu lajur:
df.pivot(index='row', columns='col', values='val')
Salin selepas log masuk
  • Pivot pada berbilang lajur:
df.pivot(index=['row', 'item'], columns='col', values='val')
Salin selepas log masuk
  • Pivot pada berbilang nilai:
df.pivot(index='row', columns='col', values=['val0', 'val1'])
Salin selepas log masuk
  • Pivot dengan fungsi pengagregatan tersuai:
df.pivot(index='row', columns='col', values='val', aggfunc='mean')
Salin selepas log masuk
  • Mengendalikan pendua kunci:

Secara lalai, jika terdapat kekunci pendua dalam label baris atau lajur, ralat akan ditimbulkan. Sebagai alternatif, anda boleh menggunakan:

df.pivot_table(index='row', columns='col', values='val', fill_value=0)
Salin selepas log masuk
  • Kaedah lain untuk berputar:
  • groupby unstack:

    df.groupby('row', 'col')['val'].mean().unstack(fill_value=0)
    Salin selepas log masuk
  • pd.DataFrame .set_index: Gunakan set_index untuk menetapkan paksi baris dan lajur dan kemudian nyahtindan ke pivot.
  • pd.crosstab: Direka khusus untuk mencipta penjadualan silang atau jadual pangsi.

Teknik Pivoting Lanjutan:

  • Penjadualan silang (frekuensi mengira):
pd.crosstab(index=df['row'], columns=df['col'], values=df['val'], aggfunc='count')
Salin selepas log masuk
  • Berbilang fungsi pengagregatan:
df.pivot_table(index='row', columns='col', values='val', aggfunc=['mean', 'sum'])
Salin selepas log masuk
  • Membahagikan dengan berbilang lajur:
df.pivot_table(index='row', columns=['item', 'col'], values='val', fill_value=0, aggfunc='mean')
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimanakah saya Boleh Memusingkan Pandas DataFrame dengan Berkesan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan