利用Lambda/LINQ高效過濾包含多個關鍵字的集合
問題:
如何有效率地使用Lambda表達式或LINQ根據多個關鍵字過濾集合?
解:
問題中給出的範例強調了在一個欄位(此處為「Comments」欄位)中檢查多個關鍵字的需求。雖然有基於單一關鍵字過濾的範例,但將此邏輯擴展到多個關鍵字需要更強大的方法。
Lambda表達式方法:
我們可以利用答案中提供的擴充方法,使用Lambda表達式來實現此需求:
<code class="language-csharp">var newList = MainList .FilterByItems(keywords, (m, k) => m.Comments.Contains(k), true) .ToList();</code>
LINQ方法:
或者,我們可以使用LINQ來達到相同的結果:
<code class="language-csharp">var newList = MainList.Where(m => keywords.Any(k => m.Comments.Contains(k)));</code>
解釋:
兩種方法都使用了QueryableExtensions類別中的FilterByItems擴充方法。此方法接受一個項目集合、一個要套用的謂詞和一個布林值,該布林值指示是否執行「OR」或「AND」操作。
在我們的例子中,我們將關鍵字清單作為項目傳遞,一個謂詞檢查Comments欄位是否包含每個關鍵字,並將isOr設為true以執行「OR」操作。這可確保如果記錄包含任何指定的關鍵字,則將其包含在結果中。
FilterByItems擴充方法的實作:
FilterByItems方法使用ExpressionReplacer類別實現,該類別允許我們替換表達式的部分內容。這用於產生一個檢查每個關鍵字是否存在謂詞。
範例用法:
要使用FilterByItems方法,我們只需提供要過濾的集合、要檢查的關鍵字列表,並可選擇將isOr設為true表示「OR」操作,或設定為false表示「AND」操作。
<code class="language-csharp">// 过滤“Comments”字段中的关键词 var filteredList = MainList.FilterByItems(keywords, (m, k) => m.Comments.Contains(k)); // 使用OR操作包含任何匹配关键词的记录 var newList = MainList.FilterByItems(keywords, (m, k) => m.Comments.Contains(k), true);</code>
以上是如何使用 Lambda/LINQ 基於多個關鍵字高效過濾集合?的詳細內容。更多資訊請關注PHP中文網其他相關文章!