using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace IStation.Application { /// /// 能效汇总单日辅助类 /// public class EtaSumSingleDayHelper { /// /// 汇总 /// public static Model.EtaSumSingleDayRecord Sum ( long CorpID, string ObjectType, long ObjectID, DateTime Day, IEnumerable records ) { if (records == null || records.Count() < 1) return default; var run_record_list = records.Where(x => x.RSa == RunStatus.Run).ToList(); var run_normal_record_list = run_record_list.Where(x => x.AnalyStatus == Model.Eta.eAnalyStatus.Normal).ToList(); var model = new Model.EtaSumSingleDayRecord(); model.CorpID = CorpID; model.ObjectType = ObjectType; model.ObjectID = ObjectID; model.DataDay = Day.Date; model.DataTime = DateTime.Now; model.Qt = run_record_list.Sum(x => (x.Qa ?? 0) * x.Duration) / 3600f; model.Dt = run_record_list.Sum(x => (x.Pa ?? 0) * x.Duration) / 3600f; model.RunTime = run_record_list.Sum(x => x.Duration); model.PointCount = run_record_list.Count; if (run_normal_record_list.Count > 0) { if (run_normal_record_list.Exists(x => x.Qa.HasValue)) { model.Qmin = run_normal_record_list.Where(x => x.Qa.HasValue).Min(x => x.Qa.Value); model.Qmax = run_normal_record_list.Where(x => x.Qa.HasValue).Max(x => x.Qa.Value); model.Qavg = run_normal_record_list.Where(x => x.Qa.HasValue).Average(x => x.Qa.Value); } if (run_normal_record_list.Exists(x => x.Ha.HasValue)) { model.Hmin = run_normal_record_list.Where(x => x.Ha.HasValue).Min(x => x.Ha.Value); model.Hmax = run_normal_record_list.Where(x => x.Ha.HasValue).Max(x => x.Ha.Value); model.Havg = run_normal_record_list.Where(x => x.Ha.HasValue).Average(x => x.Ha.Value); } if (run_normal_record_list.Exists(x => x.Ea.HasValue)) { model.Emin = run_normal_record_list.Where(x => x.Ea.HasValue).Min(x => x.Ea.Value); model.Emax = run_normal_record_list.Where(x => x.Ea.HasValue).Max(x => x.Ea.Value); model.Eavg = run_normal_record_list.Where(x => x.Ea.HasValue).Average(x => x.Ea.Value); } if (run_normal_record_list.Exists(x => x.Pa.HasValue)) { model.Pmin = run_normal_record_list.Where(x => x.Pa.HasValue).Min(x => x.Pa.Value); model.Pmax = run_normal_record_list.Where(x => x.Pa.HasValue).Max(x => x.Pa.Value); model.Pavg = run_normal_record_list.Where(x => x.Pa.HasValue).Average(x => x.Pa.Value); } if (run_normal_record_list.Exists(x => x.WPa.HasValue)) { model.WPmin = run_normal_record_list.Where(x => x.WPa.HasValue).Min(x => x.WPa.Value); model.WPmax = run_normal_record_list.Where(x => x.WPa.HasValue).Max(x => x.WPa.Value); model.WPavg = run_normal_record_list.Where(x => x.WPa.HasValue).Average(x => x.WPa.Value); } if (run_normal_record_list.Exists(x => x.UWPa.HasValue)) { model.UWPmin = run_normal_record_list.Where(x => x.UWPa.HasValue).Min(x => x.UWPa.Value); model.UWPmax = run_normal_record_list.Where(x => x.UWPa.HasValue).Max(x => x.UWPa.Value); model.UWPavg = run_normal_record_list.Where(x => x.UWPa.HasValue).Average(x => x.UWPa.Value); } } if (run_record_list.Count > 1) { var run_boot_list = run_record_list.OrderBy(x => x.DataTime).ToList(); for (int j = 1; j < run_boot_list.Count; j++) { if ((run_boot_list[j].DataTime - run_boot_list[j - 1].DataTime).TotalSeconds > 5 * run_boot_list[j].Duration) { model.BootTimes += 1; } } } return model; } } }