cari
Rumahpembangunan bahagian belakangTutorial PythonBagaimana untuk Menggabungkan DataFrames mengikut Keadaan Julat dalam Pandas Menggunakan Numpy Broadcasting?

How to Merge DataFrames by Range Condition in Pandas Using Numpy Broadcasting?

Gabungkan Bingkai Data mengikut Keadaan Julat dalam Panda

Dalam bidang analisis data, menggabungkan data daripada pelbagai sumber ialah tugas biasa. Pandas, perpustakaan Python yang berkuasa untuk manipulasi data, menyediakan pelbagai kaedah untuk menggabungkan bingkai data, termasuk keadaan julat. Artikel ini menyelidiki senario khusus ini dan membentangkan penyelesaian yang cekap menggunakan penyiaran numpy.

Penerangan Masalah

Memandangkan dua bingkai data, A dan B, matlamatnya adalah untuk melaksanakan inner join di mana nilai dalam bingkai data A berada dalam julat tertentu yang ditakrifkan dalam bingkai data B. Secara tradisinya, ini akan dicapai menggunakan sintaks SQL:

<code class="sql">SELECT *
FROM A, B
WHERE A_value BETWEEN B_low AND B_high</code>

Penyelesaian Sedia Ada

Panda menawarkan penyelesaian menggunakan lajur tiruan, bergabung pada lajur tiruan, dan kemudian menapis baris yang tidak diperlukan. Walau bagaimanapun, kaedah ini adalah berat dari segi pengiraan. Sebagai alternatif, seseorang boleh menggunakan fungsi carian untuk setiap nilai A pada B, tetapi pendekatan ini juga mempunyai kelemahan.

Penyiaran Numpy: Pendekatan Pragmatik

Penyiaran Numpy menyediakan penyelesaian yang elegan dan cekap. Teknik ini memanfaatkan kevektoran untuk melakukan pengiraan pada keseluruhan tatasusunan dan bukannya elemen individu. Untuk mencapai gabungan yang diingini:

  1. Ekstrak nilai daripada bingkai data A dan B.
  2. Gunakan penyiaran numpy untuk mencipta topeng boolean:

    • A_value >= B_low
    • A_value
  3. Gunakan np.where numpy untuk mencari indeks di mana topeng adalah True.
  4. Concatenate baris yang sepadan daripada bingkai data A dan B berdasarkan indeks yang dikenal pasti.

Pendekatan ini menggunakan penyiaran untuk melaksanakan perbandingan julat pada keseluruhan bingkai data A, dengan ketara mengurangkan masa dan kerumitan pengiraan.

Contoh

Pertimbangkan rangka data berikut:

<code class="python">A = pd.DataFrame(dict(
    A_id=range(10),
    A_value=range(5, 105, 10)
))
B = pd.DataFrame(dict(
    B_id=range(5),
    B_low=[0, 30, 30, 46, 84],
    B_high=[10, 40, 50, 54, 84]
))</code>

Output:

   A_id  A_value  B_high  B_id  B_low
0     0        5      10     0      0
1     3       35      40     1     30
2     3       35      50     2     30
3     4       45      50     2     30

Output ini menunjukkan kejayaan gabungan bingkai data A dan B berdasarkan keadaan julat yang ditentukan.

Pertimbangan Tambahan

Untuk melakukan cantuman kiri, masukkan baris yang tidak sepadan daripada bingkai data A dalam output. Ini boleh dicapai dengan menggunakan ~np.in1d ​​numpy untuk mengenal pasti baris yang tidak sepadan dan menambahkannya pada hasilnya.

Kesimpulannya, penyiaran numpy menawarkan pendekatan yang mantap dan cekap untuk menggabungkan bingkai data berdasarkan keadaan julat. Keupayaan vektorisasinya meningkatkan prestasi, menjadikannya penyelesaian ideal untuk set data yang besar.

Atas ialah kandungan terperinci Bagaimana untuk Menggabungkan DataFrames mengikut Keadaan Julat dalam Pandas Menggunakan Numpy Broadcasting?. 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
Cara Menggunakan Python untuk Mencari Pengagihan Zipf Fail TeksCara Menggunakan Python untuk Mencari Pengagihan Zipf Fail TeksMar 05, 2025 am 09:58 AM

Tutorial ini menunjukkan cara menggunakan Python untuk memproses konsep statistik undang -undang ZIPF dan menunjukkan kecekapan membaca dan menyusun fail teks besar Python semasa memproses undang -undang. Anda mungkin tertanya -tanya apa maksud pengedaran ZIPF istilah. Untuk memahami istilah ini, kita perlu menentukan undang -undang Zipf. Jangan risau, saya akan cuba memudahkan arahan. Undang -undang Zipf Undang -undang Zipf hanya bermaksud: Dalam korpus bahasa semulajadi yang besar, kata -kata yang paling kerap berlaku muncul kira -kira dua kali lebih kerap sebagai kata -kata kerap kedua, tiga kali sebagai kata -kata kerap ketiga, empat kali sebagai kata -kata kerap keempat, dan sebagainya. Mari kita lihat contoh. Jika anda melihat corpus coklat dalam bahasa Inggeris Amerika, anda akan melihat bahawa perkataan yang paling kerap adalah "th

Bagaimana saya menggunakan sup yang indah untuk menghuraikan html?Bagaimana saya menggunakan sup yang indah untuk menghuraikan html?Mar 10, 2025 pm 06:54 PM

Artikel ini menerangkan cara menggunakan sup yang indah, perpustakaan python, untuk menghuraikan html. Ia memperincikan kaedah biasa seperti mencari (), find_all (), pilih (), dan get_text () untuk pengekstrakan data, pengendalian struktur dan kesilapan HTML yang pelbagai, dan alternatif (sel

Cara memuat turun fail di pythonCara memuat turun fail di pythonMar 01, 2025 am 10:03 AM

Python menyediakan pelbagai cara untuk memuat turun fail dari Internet, yang boleh dimuat turun melalui HTTP menggunakan pakej Urllib atau Perpustakaan Permintaan. Tutorial ini akan menerangkan cara menggunakan perpustakaan ini untuk memuat turun fail dari URL dari Python. Permintaan Perpustakaan Permintaan adalah salah satu perpustakaan yang paling popular di Python. Ia membolehkan menghantar permintaan HTTP/1.1 tanpa menambahkan rentetan pertanyaan secara manual ke URL atau pengekodan data pos. Perpustakaan Permintaan boleh melaksanakan banyak fungsi, termasuk: Tambah data borang Tambah fail berbilang bahagian Akses data tindak balas python Buat permintaan kepala

Penapisan gambar di pythonPenapisan gambar di pythonMar 03, 2025 am 09:44 AM

Berurusan dengan imej yang bising adalah masalah biasa, terutamanya dengan telefon bimbit atau foto kamera resolusi rendah. Tutorial ini meneroka teknik penapisan imej di Python menggunakan OpenCV untuk menangani isu ini. Penapisan Imej: Alat yang berkuasa Penapis Imej

Cara Bekerja Dengan Dokumen PDF Menggunakan PythonCara Bekerja Dengan Dokumen PDF Menggunakan PythonMar 02, 2025 am 09:54 AM

Fail PDF adalah popular untuk keserasian silang platform mereka, dengan kandungan dan susun atur yang konsisten merentasi sistem operasi, peranti membaca dan perisian. Walau bagaimanapun, tidak seperti Python memproses fail teks biasa, fail PDF adalah fail binari dengan struktur yang lebih kompleks dan mengandungi unsur -unsur seperti fon, warna, dan imej. Mujurlah, tidak sukar untuk memproses fail PDF dengan modul luaran Python. Artikel ini akan menggunakan modul PYPDF2 untuk menunjukkan cara membuka fail PDF, mencetak halaman, dan mengekstrak teks. Untuk penciptaan dan penyuntingan fail PDF, sila rujuk tutorial lain dari saya. Penyediaan Inti terletak pada menggunakan modul luaran PYPDF2. Pertama, pasangkannya menggunakan PIP: Pip adalah p

Cara Cache Menggunakan Redis dalam Aplikasi DjangoCara Cache Menggunakan Redis dalam Aplikasi DjangoMar 02, 2025 am 10:10 AM

Tutorial ini menunjukkan cara memanfaatkan caching redis untuk meningkatkan prestasi aplikasi python, khususnya dalam rangka kerja Django. Kami akan merangkumi pemasangan Redis, konfigurasi Django, dan perbandingan prestasi untuk menyerlahkan bene

Memperkenalkan Toolkit Bahasa Alam (NLTK)Memperkenalkan Toolkit Bahasa Alam (NLTK)Mar 01, 2025 am 10:05 AM

Pemprosesan bahasa semulajadi (NLP) adalah pemprosesan bahasa manusia secara automatik atau separa automatik. NLP berkait rapat dengan linguistik dan mempunyai hubungan dengan penyelidikan dalam sains kognitif, psikologi, fisiologi, dan matematik. Dalam sains komputer

Bagaimana untuk melakukan pembelajaran mendalam dengan Tensorflow atau Pytorch?Bagaimana untuk melakukan pembelajaran mendalam dengan Tensorflow atau Pytorch?Mar 10, 2025 pm 06:52 PM

Artikel ini membandingkan tensorflow dan pytorch untuk pembelajaran mendalam. Ia memperincikan langkah -langkah yang terlibat: penyediaan data, bangunan model, latihan, penilaian, dan penempatan. Perbezaan utama antara rangka kerja, terutamanya mengenai grap pengiraan

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual