Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Meratakan IEnumerable Bersarang dalam LINQ?

Bagaimanakah Saya Boleh Meratakan IEnumerable Bersarang dalam LINQ?

Susan Sarandon
Susan Sarandonasal
2025-01-26 15:51:09941semak imbas

How Can I Flatten a Nested IEnumerable in LINQ?

iEnumerable

Di linq, anda mungkin menghadapi kes bersarang, dan anda perlu "menyanjung" untuk mendapatkan satu penggabungan yang menggabungkan. Apabila ienumeration dalaman mengandungi jenis elemen yang sama seperti ienumable luaran, proses rata menjadi perlu.

Kajian kes:

pertimbangkan contoh yang disediakan:

Dalam contoh ini, ilist mewakili ienumeration bersarang, masing -masing adalah senarai

. Matlamatnya adalah untuk menggabungkan semua senarai bersarang ini ke satu senarai
<code>IEnumerable<List<int>> iList = from number in
    (from no in Method() select no) select number;</code>
.

Penyelesaian: SelectMany ()

Linq menyediakan kaedah selectMany (), yang digunakan secara khusus untuk menunjukkan koleksi yang dapat diratakan. Ia melintasi luaran yang tidak dapat dilupakan dan memproyeksikan setiap elemen set dalaman ke dalam iEnumerable baru.

Untuk mendapatkan hasil yang diperlukan, anda boleh menggunakan selectMany ():

Dalam kod ini, kaedah pemilihanMany () memperoleh setiap senarai yang terkandung dalam ilist (diwakili oleh Variable I), dan menghubungkan elemen senarai ke pameran baru yang dinamakan hasil yang tidak terhitung.

Contoh:

<code>var result = iList.SelectMany(i => i);</code>

Melalui pameran ini rata, array bersarang asal [1,2,3,4] dan [5,6,7] akan digabungkan menjadi satu array seperti yang dijangkakan [1,2,3,4,5,6 , 7].

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Meratakan IEnumerable Bersarang dalam LINQ?. 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