【问题标题】:C# filter the datatable and calculate [closed]C#过滤数据表并计算[关闭]
【发布时间】:2016-02-16 17:59:39
【问题描述】:

我正在编写带有数据表的 C# 代码。

表格是这样的:

ID 区域 day1 day2 day3 day4

1 0.1 0.1 0.1 0.1

b 1 0.1 0.1 0.1 0.1

c 1 0.1 0.1 0.1 0.1

d 2 0.1 0.1 0.1 0.1

e 2 0.1 0.1 0.1 0.1

我想用区号过滤数据表并将同一区域中的行汇总在一起?实现这个功能的好方法是什么?

【问题讨论】:

  • 查看 WHERE(过滤)和 SUM。写一些代码。如果您仍然卡住,请发布该代码(指出您卡住的确切位置)。

标签: c# filter datatable


【解决方案1】:

这很简单。按区号过滤,按地区分组,然后总结所有天数:

DataTable table = new DataTable();
table.Columns.Add("ID", typeof(string));
table.Columns.Add("Area", typeof(int));
table.Columns.Add("Day1", typeof(double));
table.Columns.Add("Day2", typeof(double));
table.Columns.Add("Day3", typeof(double));
table.Columns.Add("Day4", typeof(double));

table.Rows.Add("a", 1, 0.1, 0.1, 0.1, 0.1);
table.Rows.Add("b", 1, 0.1, 0.1, 0.1, 0.1);
table.Rows.Add("c", 1, 0.1, 0.1, 0.1, 0.1);
table.Rows.Add("d", 2, 0.1, 0.1, 0.1, 0.1);
table.Rows.Add("e", 2, 0.1, 0.1, 0.1, 0.1);

var result = table.AsEnumerable().Where (t => t.Field<int>("Area") == 1)
                                 .GroupBy (t => t.Field<int>("Area"))
                                 .Select(x => new {
                                    Area = x.Key,
                                    Day1 = x.Sum (y => y.Field<double>("Day1")),
                                    Day2 = x.Sum (y => y.Field<double>("Day2")),
                                    Day3 = x.Sum (y => y.Field<double>("Day3")),
                                    Day4 = x.Sum (y => y.Field<double>("Day4"))
                                 });
result.Dump();

输出:

Linqpad 来源:http://share.linqpad.net/fqwflw.linq

参考资料:

【讨论】:

  • 非常感谢!这行得通!
  • 但是对于一个大约1000行4000列的非常大的表,有没有好的计算方法?
  • 你为什么不试试
猜你喜欢
  • 2021-12-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-06-18
  • 2023-04-09
  • 2017-11-06
  • 2020-07-14
  • 1970-01-01
相关资源
最近更新 更多