我在工作中遇到一个问题,现有A-Z 26个文件夹,有一个Excel表,其中包含了每个文件夹中赛选出来的文件的文件名,我已经把Excel表里的内容导入到一个DataTable,并遍历每行数据指定的路径,得到每个文件的大小,但现在想的到每个文件夹中赛选出的文件总大小。如果数据存在数据库,就可用SELECT GROUP BY来获取,但是我获取的数据都存在DataTable里不支持SQL语句,不知道用DataView能不能实现,也不想把数据存到数据库在进行筛选
调试欢乐多
本文介绍一个简单的方法,不需要逐条记录进行计算就可以轻松的获得DataTable中的记录统计结果。这个简单的方法就是调用功能强大的DataTable的函数Compute。
一、调用说明(仅以C#为例,下同):
public object Compute(string strExpression,string strFilter)
参数:
strExpression:要计算的表达式字符串,基本上类似于Sql Server中的统计表达式
strFilter:统计的过滤字符串,只有满足这个过滤条件的记录才会被统计
二、调用举例:
以下示例,假设一个产品销售表table,描述某商场中各促销员销售的实际记录,包含字段为:姓名(Name)、性别(Sex,0为女,1为男)、生日(Birthday)、销售产品的代码(ProID)、销售的数量(Quantity)、销售价格(Price)。
1.统计所有性别为女的销售员的数量:
table.Compute("Count(*)","Sex=0");
2.统计所有销售员中年龄大于20岁的
table.Compute("Count(*)","Birthday<'"+today);//today为今天的日期字符串
3.统计销售产品的平均价格
table.Compute("Aver(Price)","true");
4.统计产品代码为1的产品销售数量:
table.Compute("Sum(Quantity)","ProID=1");
5.统计所有产品的销售总金额:
要统计总销售金额,由于table中不存在某项产品某个促销员销售的金额数据,但我们可以通过Quantity*Price来获得。比如:
table.Compute("Sum(Quantity*Price)","true");
这里一个问题是:DataTable的统计功能没有SqlServer强,这个统计是错误的,因为Compute的统计不具备Sum(Quantity*Price)这样数据的功能。那怎么办呢?
对于这样复杂数据的统计,我们可以在DataTable中创建一个新的字段来完成,比如Amount,同时设置该字段的Expression为Quantity*Price,这样我们就可以使用统计功能了:
table.Compute("Sum(Amount)","true");
datatable.select(表达式);具体可参考msdn