gpt4 book ai didi

c# - 使用 .NET 中的 linq 计算 dataGridView 中列的不同值

转载 作者:太空狗 更新时间:2023-10-29 22:11:02 24 4
gpt4 key购买 nike

我需要在 dataGridView 中计算并显示不同/唯一的值。我想像这样展示它,并且这段代码适用于列表。

        List<string> aryIDs = new List<string>();
aryIDs.Add("1234");
aryIDs.Add("4321");
aryIDs.Add("3214");
aryIDs.Add("1234");
aryIDs.Add("4321");
aryIDs.Add("1234");

var result= aryIDs.GroupBy(id => id).OrderByDescending(id => id.Count()).Select(g => new { Id = g.Key, Count = g.Count() });

但是,当我尝试对 dataGridView 中的列使用相同的方法时,我收到一条错误消息,指出无法在我的 dataGridView 上使用 groupBy。

        DataGridView dataGridView1= new DataGridView();
dataGridView1.Columns.Add("nr", "nr");
string[] row1 = new string[] { "1234" };
string[] row2 = new string[] { "4321" };
string[] row3 = new string[] { "3214" };
string[] row4 = new string[] { "1234" };
string[] row5 = new string[] { "4321" };
string[] row6 = new string[] { "1234" };

object[] rows = new object[] { row1, row2, row3, row4, row5, row6 };

foreach (string[] rowArray in rows)
{
dataGridView1.Rows.Add(rowArray);
}

var result = dataGridView1.GroupBy(id => id).OrderByDescending(id => id.Count()).Select(g => new { Id = g.Key, Count = g.Count() });

所以我的问题是,如何调整此 linq 语法以处理 dataGridView 中的列?如果可能的话,我根本不想使用列表。

最佳答案

这将适用于您的示例:

var result = dataGridView1.Rows.Cast<DataGridViewRow>()
.Where(r => r.Cells[0].Value != null)
.Select (r => r.Cells[0].Value)
.GroupBy(id => id)
.OrderByDescending(id => id.Count())
.Select(g => new { Id = g.Key, Count = g.Count() });

关于c# - 使用 .NET 中的 linq 计算 dataGridView 中列的不同值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10899568/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com