Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Mencipta Tatasusunan NumPy Padat daripada Senarai Panjang Pembolehubah?
Penukaran standard jujukan Python yang mengandungi senarai panjang boleh ubah kepada tatasusunan NumPy mencipta tatasusunan jenis objek. Menguatkuasakan jenis data lain menimbulkan ValueError. Artikel ini menunjukkan kaedah yang cekap untuk menjana tatasusunan NumPy padat jenis int32 dengan mengisi nilai yang tiada dengan pemegang tempat.
Untuk menukar urutan senarai panjang pembolehubah kepada tatasusunan NumPy, seseorang boleh menggunakan itertools.zip_longest fungsi daripada modul itertools. Fungsi ini berulang melalui senarai, berhenti apabila senarai terpendek telah habis. Ia mengisi nilai yang tiada dalam senarai yang lebih panjang dengan nilai pemegang tempat yang ditentukan oleh argumen nilai isian.
Sebagai contoh, pertimbangkan urutan senarai panjang pembolehubah berikut:
v = [[1], [1, 2]]
Untuk menjana NumPy padat tatasusunan daripada jujukan ini, dengan nilai pemegang tempat 0, seseorang boleh menggunakan kod berikut:
<code class="python">import itertools np.array(list(itertools.zip_longest(*v, fillvalue=0))).T</code>
Output kod ini akan menjadi tatasusunan NumPy jenis int32, dengan nilai yang tiada digantikan dengan 0:
array([[1, 0], [1, 2]])
Kaedah ini menyediakan cara yang cekap untuk mengendalikan senarai panjang boleh ubah apabila menukarnya kepada tatasusunan NumPy, memastikan ketekalan jenis data dan mengisi nilai yang tiada dengan ruang letak yang dikehendaki.
Atas ialah kandungan terperinci Bagaimana untuk Mencipta Tatasusunan NumPy Padat daripada Senarai Panjang Pembolehubah?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!