簡體   English   中英

Linq 帶 OrderBy 字數的查詢

[英]Linq query with OrderBy word count

我有這段代碼,

 public static List<string> GetSentencesFromWords(List<string> words, string fileContents)
{
    return fileContents.Split('.')
        .Where(s => words.Any(w => s.IndexOf(w) != -1))
        .Select(s => s.TrimStart(' ') + ".")
        .ToList();
}

它工作得很好,另一個用戶在另一個問題中幫助我解決了這個問題,但我認為與它相關的新問題需要一個新帖子。 我需要返回的單詞列表按每個句子中的匹配數排序。 我嘗試過幾種方法,但我對 Linq 不是很有經驗,我嘗試過的所有內容似乎都是按句子長度而不是字數排序。

試試這個,它應該適合你?

return fileContents.Split('.')
    .Where(s => words.Any(w => s.IndexOf(w) != -1))
    .Select(s => s.TrimStart(' ') + ".")
    .OrderByDescending(s => words.Count(w => s.IndexOf(w) != -1))
    .ToList();

那這個呢:

return fileContents.Split('.')
   .Where(s => words.Any(w => s.Contains(w) != -1))
   .Select(s => s.TrimStart(' ') + ".")
   .OrderByDescending(s => words.Sum(w => Regex.Matches(s, w).Count))
   .ToList();

不要忘記using System.Text.RegularExpressions

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM