Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Mengira Kejadian Perkataan dengan Cekap dalam Senarai Python?

Bagaimana untuk Mengira Kejadian Perkataan dengan Cekap dalam Senarai Python?

DDD
DDDasal
2024-10-30 17:02:26940semak imbas

How to Efficiently Count Word Occurrences in a Python List?

Pengiraan Frekuensi Item dalam Python

Bagaimanakah anda cekap mengira kejadian setiap perkataan unik dalam senarai yang diberikan? Pertimbangkan kod berikut:

<code class="python">words = "apple banana apple strawberry banana lemon"
uniques = set(words.split())
freqs = [(item, words.split().count(item)) for item in uniques]
print(freqs)</code>

Semasa kaedah ini berfungsi, ia memerlukan dua lelaran melalui senarai, sekali untuk mencipta set perkataan unik dan sekali lagi untuk mengira penampilan. Bolehkah kita mengoptimumkan ini?

Penyelesaian: Menggunakan Kelas Kaunter

Modul koleksi Python menyediakan kelas Kaunter yang direka khusus untuk tugasan ini. Begini cara anda boleh menggunakannya:

<code class="python">from collections import Counter
words = "apple banana apple strawberry banana lemon"
Counter(words.split())
# Output: Counter({'apple': 2, 'banana': 2, 'strawberry': 1, 'lemon': 1})</code>

Kelas Counter mengira kejadian setiap item dalam lelaran yang disediakan, menghasilkan kamus di mana kunci adalah item unik dan nilai adalah kiraan mereka. Pendekatan ini lebih cekap kerana ia hanya memerlukan satu lelaran melalui senarai input.

Atas ialah kandungan terperinci Bagaimana untuk Mengira Kejadian Perkataan dengan Cekap dalam Senarai Python?. 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