【发布时间】:2020-01-24 17:02:37
【问题描述】:
我正在开发一个 WPF 应用程序,在某一时刻,我必须从字符串列表中获取/显示所有重复项。 (带有重复的字符串名称和列表中相同字符串的数量)例如:“列表包含字符串 'Hello' 3 次。”到目前为止,我成功地获得了字符串的名称,但我无法获得它在列表中出现的正确次数。 到目前为止,这是我的代码:
List<String> answerData = new List<String>();
using (MySqlCommand command = new MySqlCommand(query2, conn))
{
using (MySqlDataReader reader = command.ExecuteReader())
{
while (reader.Read())
{
answerData.Add(reader.GetString(0));
}
}
}
var duplicates = answerData
.GroupBy(i => i)
.Where(g => g.Count() > 1)
.Select(g => g.Key);
foreach (var d in duplicates)
{
MessageBox.Show(""+ d + duplicates.Count().ToString()); //Here I tried to get the number
//with Count() but it doesn't work as I thought it would.
}
我应该添加/更改什么以获得我想要的结果?
编辑
按照建议将我的代码更改为以下内容:
var duplicates = answerData
.GroupBy(i => i)
.Where(g => g.Count() > 1);
foreach (var d in duplicates)
{
MessageBox.Show(d.Key + " " + d.Count().ToString());
}
现在它运行顺利。 谢谢大家!
【问题讨论】:
-
您只是选择密钥作为返回。删除最后一个
Select -
.Select(g => g.Key)您只选择了密钥。如果你想要计数,你应该得到它new {g.Key g.Count()} -
.Select(g => new {key = g.Key, count = g.Count()}).ToList();