【问题标题】:Averaging every column in a DataTable平均数据表中的每一列
【发布时间】:2014-09-29 13:18:32
【问题描述】:

我目前正在使用以下 LINQ 语句从我的 DataTable 中提取某些数据

var possibleRows = _Data.Select("Distance > " + (location.Distance - delta) + " AND Distance < " + (location.Distance + delta));

我想最终得到一个 DataRow,它包含上面 select 语句中每一列的平均值,而不必遍历每一列。我有超过 100 列,所有数据都是数字。有没有简单的方法来做到这一点?

【问题讨论】:

  • 请指定您当前拥有哪些列、您希望生成的有效输入和输出。假设你的输入行有字符串数据,你会如何处理呢?
  • 我有超过 100 列的双重数据。我将更改问题以反映这一点。
  • 你可以只指定 3-5 列并为其提供输入/输出,然后像这样提及 95 列。

标签: c# linq datatable


【解决方案1】:

你可以这样做:

var rows = possibleRows.Cast<DataRow>();
var averages = table.Columns.Cast<DataColumn>()
    .Select(col => new {
        Column = col,
        Average = rows.Average(row => (double)row[col])
    }).ToList();

请注意,这始终假定double

请注意,这不会导致 DataRow;它产生List&lt;&gt;,其中列表中的每个项目都有列和该列的平均值。

【讨论】:

  • 你不知道有什么好的方法来结束 DataRow 输出吗?
  • @PlTaylor 好吧...你为什么想要DataRow?您总是可以将结尾更改为.Select(col =&gt; (object)rows.Average(row =&gt; (double)row[col]).ToArray().Add,将object[] 更改为现有表...
  • 我想要数据行输出的最大原因是让我的界面与产品中已有的内容保持一致。
  • @PlTaylor 我似乎记得table.Clone() 不包括行,因此您也可以简单地克隆旧表,然后使用将结果添加到克隆中-然后您有一个表正好 1 行
  • 我遇到了一个奇怪的异常,即使我知道它们是,它仍在努力将值转换为两倍。我什至不确定这里有哪些有用的信息。
猜你喜欢
  • 1970-01-01
  • 2020-04-02
  • 2022-01-16
  • 1970-01-01
  • 2018-06-03
  • 1970-01-01
  • 1970-01-01
  • 2017-07-20
  • 2018-01-03
相关资源
最近更新 更多