square_cubes = [res if (res := n**2) % 9 == 0 or res % 4 == 0 else n**3 for n in range(1, 11)] print(square_cubes) # 输出: [1, 4, 9, 16, 125, 36, 343, 64, 81, 100]di sini, kami menyimpan pembolehubah
untuk menyimpan hasil pengiraan res
dan menggunakannya semula dalam kod berikutnya untuk mengelakkan pengiraan berulang. n**2
Senarai pemahaman menyokong gelung bersarang, dan tidak ada batasan bilangan gelung. Tetapi perlu diperhatikan bahawa urutan gelung mesti konsisten dengan kod asal. Anda juga boleh menambah keadaan
pilihan selepas setiap for
kitaran. Struktur pemahaman senarai bersarang for
gelung adalah seperti berikut: if
for
[ for in (可选 if ) for in (可选 if ) for in (可选 if ) ... ]
menukarnya ke pemahaman senarai:
multiplications = [] for i in range(1, 4): for n in range(1, 11): multiplications.append(i*n) print(multiplications) # 输出: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 3, 6, 9, 12, 15, 18, 21, 24, 27, 30]
pemahaman senarai juga boleh digunakan untuk meratakan senarai bersarang:
multiplications = [i*n for i in range(1,4) for n in range(1,11)] print(multiplications) # 输出: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 3, 6, 9, 12, 15, 18, 21, 24, 27, 30]
Pemahaman Senarai Bersarang
matrix = [ [1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], ] flatten = [n for row in matrix for n in row] print(flatten) # 输出: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
Pemahaman senarai bersarang adalah berbeza daripada pemahaman senarai gelung bersarang. Yang pertama adalah derivasi bersarang dalaman yang disimpulkan, manakala yang terakhir adalah gelung bersarang dalaman gelung. Sebagai contoh, matriks transpose:
Gunakan gelung biasa:
Gunakan pemahaman senarai bersarang:
matrix = [ [1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], ] transpose = [] for i in range(4): temp = [] for row in matrix: temp.append(row[i]) transpose.append(temp) print(transpose) # 输出: [[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
set dan derivasi kamus
matrix = [ [1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], ] transpose = [[row[n] for row in matrix] for n in range(4)] print(transpose) # 输出: [[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
Konsep pemahaman senarai juga terpakai untuk menetapkan dan pemantauan kamus. Kamus digunakan untuk menyimpan pasangan nilai utama:
set terbitan digunakan untuk membuat set yang tidak teratur:
squares_cubes = {n: n**2 if n%2 == 0 else n**3 for n in range(1,11)} print(squares_cubes) # 输出: {1: 1, 2: 4, 3: 27, 4: 16, 5: 125, 6: 36, 7: 343, 8: 64, 9: 729, 10: 100}
Ringkasan
import random non_multiples = {n for n in random.sample(range(0, 1001), 20) if n not in range(0, 1001, 9)} print(non_multiples) # 输出 (示例): {3, 165, 807, 574, 745, 266, 616, 44, 12, 910, 336, 145, 755, 179, 25, 796, 926}
Artikel ini memperkenalkan pemantauan senarai Python dan aplikasi mereka dalam pengoptimuman kod, termasuk gelung bersarang, derivasi bersarang, dan derivasi koleksi dan kamus. Harus diingat bahawa untuk gelung bersarang kompleks, untuk meningkatkan kebolehbacaan kod, pemahaman senarai boleh dibahagikan kepada pelbagai baris. Adalah disyorkan untuk memilih kaedah yang sesuai mengikut situasi sebenar, dengan mengambil kira kecekapan kod dan kebolehbacaan.
Atas ialah kandungan terperinci Senaraikan pemantauan dalam python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

ThedifferenceBetweenaforloopandawhileloopinpythonisthataforloopisusedshiphwenthenumberofiterationsisknowninadvance, mansumwhileloopisusedwhenaconditionneedstobecheckedreepeatedlywithouthorsheer .1)

Di Python, untuk gelung sesuai untuk kes -kes di mana bilangan lelaran diketahui, sementara gelung sesuai untuk kes -kes di mana bilangan lelaran tidak diketahui dan lebih banyak kawalan diperlukan. 1) Untuk gelung sesuai untuk melintasi urutan, seperti senarai, rentetan, dan lain -lain, dengan kod ringkas dan pythonic. 2) Walaupun gelung lebih sesuai apabila anda perlu mengawal gelung mengikut syarat atau tunggu input pengguna, tetapi anda perlu memberi perhatian untuk mengelakkan gelung tak terhingga. 3) Dari segi prestasi, gelung untuk sedikit lebih cepat, tetapi perbezaannya biasanya tidak besar. Memilih jenis gelung yang betul boleh meningkatkan kecekapan dan kebolehbacaan kod anda.

Di Python, senarai boleh digabungkan melalui lima kaedah: 1) Gunakan pengendali, yang mudah dan intuitif, sesuai untuk senarai kecil; 2) Gunakan kaedah melanjutkan () untuk mengubah suai senarai asal secara langsung, sesuai untuk senarai yang perlu dikemas kini dengan kerap; 3) Gunakan senarai formula analisis, ringkas dan operasi pada unsur -unsur; 4) Gunakan fungsi iTerTools.Chain () untuk memori yang cekap dan sesuai untuk set data yang besar; 5) Gunakan * pengendali dan zip () berfungsi sesuai untuk adegan di mana unsur -unsur perlu dipasangkan. Setiap kaedah mempunyai penggunaan dan kelebihan dan kekurangan khususnya, dan keperluan dan prestasi projek harus diambil kira apabila memilih.

Forloopsareusedwhenthenumberofiterationsisknown, pemantauan yang digunakan

ToConcatenatealistOfListSinpython, useextend, listcomprehensions, itertools.chain, orrecursiveFunctions.1) extendmethodisstraightforwardbutcrosce.2)

Tomergelistsinpython, operator youCanusethe, extendmethod, listcomprehension, oritertools.chain, eachwithspecificadvantages: 1) operatorSimpleButlessefficientficorlargelists;

Dalam Python 3, dua senarai boleh disambungkan melalui pelbagai kaedah: 1) Pengendali penggunaan, yang sesuai untuk senarai kecil, tetapi tidak cekap untuk senarai besar; 2) Gunakan kaedah Extend, yang sesuai untuk senarai besar, dengan kecekapan memori yang tinggi, tetapi akan mengubah suai senarai asal; 3) menggunakan * pengendali, yang sesuai untuk menggabungkan pelbagai senarai, tanpa mengubah suai senarai asal; 4) Gunakan itertools.chain, yang sesuai untuk set data yang besar, dengan kecekapan memori yang tinggi.

Menggunakan kaedah Join () adalah cara yang paling berkesan untuk menyambungkan rentetan dari senarai di Python. 1) Gunakan kaedah Join () untuk menjadi cekap dan mudah dibaca. 2) Kitaran menggunakan pengendali tidak cekap untuk senarai besar. 3) Gabungan pemahaman senarai dan menyertai () sesuai untuk senario yang memerlukan penukaran. 4) Kaedah mengurangkan () sesuai untuk jenis pengurangan lain, tetapi tidak cekap untuk penyambungan rentetan. Kalimat lengkap berakhir.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini
