Mencari untuk membaca n baris terakhir fail ialah keperluan biasa, mengingatkan ekor -n arahan dalam sistem seperti Unix. Untuk mencapai matlamat ini, kita perlu mencari kaedah yang cekap yang boleh menyediakan kefungsian ini.
Satu pendekatan yang dicadangkan melibatkan anggaran purata panjang garisan dan secara beransur-ansur meningkatkannya sehingga mencukupi. bilangan baris dibaca. Kaedah ini, walaupun munasabah, bergantung pada anggaran panjang baris dan boleh berprestasi lebih teruk dalam senario tertentu.
Kaedah alternatif yang lebih mantap melibatkan lelaran melalui fail dalam blok. Saiz blok boleh ditala untuk prestasi optimum, dan kaedah ini tidak bergantung pada sebarang andaian tentang panjang garisan. Ia terus membaca blok sehingga jumlah baris yang dikehendaki diperolehi. Teknik ini memastikan prestasi yang konsisten dan boleh dipercayai merentas saiz fail dan panjang baris yang berbeza.
Semasa menggunakan kaedah berasaskan blok ini, adalah penting untuk mempertimbangkan saiz fail berhubung dengan sistem saiz blok sistem pengendalian (OS). Jika fail lebih kecil daripada satu blok OS, kaedah ini boleh mengakibatkan bacaan berlebihan dan prestasi yang lebih rendah. Dalam kes sedemikian, menjajarkan saiz blok dengan saiz blok OS boleh menghasilkan peningkatan. Walau bagaimanapun, untuk fail besar, pengoptimuman ini mungkin tidak mempunyai kesan yang ketara.
Pendekatan alternatif yang dicadangkan boleh dilaksanakan dalam Python seperti berikut:
def tail(f, lines=20): """Reads the last n lines from a file.""" BLOCK_SIZE = 1024 f.seek(0, 2) block_end_byte = f.tell() lines_to_go = lines block_number = -1 blocks = [] while lines_to_go > 0 and block_end_byte > 0: if (block_end_byte - BLOCK_SIZE > 0): f.seek(block_number*BLOCK_SIZE, 2) blocks.append(f.read(BLOCK_SIZE)) else: f.seek(0, 0) blocks.append(f.read(block_end_byte)) lines_found = blocks[-1].count(b'\n') # Edit for Python 3.2 and up lines_to_go -= lines_found block_end_byte -= BLOCK_SIZE block_number -= 1 all_read_text = b''.join(reversed(blocks)) # Edit for Python 3.2 and up return b'\n'.join(all_read_text.splitlines()[-lines:]) # Edit for Python 3.2 and up
Pelaksanaan ini membolehkan spesifikasi bilangan baris untuk dibaca, menjadikannya penyelesaian yang fleksibel dan serba boleh. Ia mengutamakan kekukuhan dan prestasi, mengelakkan andaian tentang panjang baris atau saiz fail.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Membaca Baris N Terakhir Fail dalam Python dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!