Memotong Senarai menjadi Segmen Sama Saiz
Memandangkan senarai panjang sewenang-wenangnya, bagaimana anda boleh membahagikannya dengan cekap kepada ketulan yang sama saiz ? Senario biasa ini timbul dalam pelbagai konteks pengaturcaraan.
Penyelesaian 1 (Penjana):
Fungsi penjana bernama chunk menyediakan pendekatan berulang untuk mencapai tugas ini:
def chunks(lst, n): """Yield successive n-sized chunks from lst.""" for i in range(0, len(lst), n): yield lst[i:i + n]
Sebagai contoh, dengan senarai nombor antara 10 hingga 74 dan ketulan saiz 10:
import pprint pprint.pprint(list(chunks(range(10, 75), 10))) # Output: [[10, 11, 12, 13, 14, 15, 16, 17, 18, 19], [20, 21, 22, 23, 24, 25, 26, 27, 28, 29], [30, 31, 32, 33, 34, 35, 36, 37, 38, 39], [40, 41, 42, 43, 44, 45, 46, 47, 48, 49], [50, 51, 52, 53, 54, 55, 56, 57, 58, 59], [60, 61, 62, 63, 64, 65, 66, 67, 68, 69], [70, 71, 72, 73, 74]]
Penyelesaian 2 (Pemahaman Senarai):
Pendekatan pemahaman senarai ringkas ialah:
[lst[i:i + n] for i in range(0, len(lst), n)]
Nota:
Sedangkan kaedah penjana lebih verbose, ia biasanya lebih disukai dalam kebolehbacaan dan kebolehselenggaraan kod. Walau bagaimanapun, pemahaman senarai menyediakan alternatif satu lapis yang mudah.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Membahagikan Senarai dengan Cekap kepada Segmen Saiz Sama?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!