C# 具有OrderBy字数的Linq查询
我有一些代码C# 具有OrderBy字数的Linq查询,c#,.net,linq,sql-order-by,C#,.net,Linq,Sql Order By,我有一些代码 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(' ')
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();
}
公共静态列表GetSentencesFromWords(列表字、字符串文件内容)
{
返回fileContents.Split(“.”)
.其中(s=>words.Any(w=>s.IndexOf(w)!=-1))
.选择(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();
别忘了包括
使用System.Text.RegularExpressions
如果一个单词在一个句子中重复会怎么样?@Hexxagonal很好的观点,但我认为他只是在寻找一个单词上有多少匹配项,而不是多个不同的单词。他只说“我需要返回的单词列表按照每个句子中匹配的数量排序”。我想,不管同一个单词是否不止一个,这仍然是一个匹配?是的,再看一遍。。。你可能是对的。现在还不完全清楚他想要什么。她想要的是一个计数,不是真正关心的次数,双打应该是非常罕见的。我说不出这个答案和另一个答案的区别,哪一个更好?哦,事实上,如果s仍然是句子,你需要更改s.IndexOf(w)!=-1到s.Split(“”)。Any(sw=>sw==w)比较句子中的每个实际单词。