最近两个月,断断续续完成了一个PPE报表的开发,和各位分享一下: PPE API的开发主要涉及到Hookup、PctLoop、PctFunction、Specification、PctElement、Plant等对象。 PPE Data: PpeData data = new PpeData(oProject); PctLoop: PctLoopFilter oPF = new PctLoopFilter(data); PctLoop[] oLoop = data.GetPctLoops(oPF); Hookup: Hookup[] oHookups = data.Hookups; pctElements: PctElement[] pctElements = oLoop[d].PctFunctions[t].PctElements; Specification: pctElements[v].Specification 因为报表中涉及到数据的分组、排序、检索,所以我选择了Linq方式: 写入数据: arrDevicePiList.Add(new DevicePiList { groupNr = 10, pctLen = d, funLen = t, piCode = strPiCode, pctFunType = "其它", oPctFun = oLoop[d].PctFunctions[t], pctFunMeasurand = oLoop[d].PctFunctions[t].Measurand, pctFunFunction = oLoop[d].PctFunctions[t].Function, pctFunNumber = oLoop[d].PctFunctions[t].Number }); 分组、排序: var cc = from t in arrDevicePiList orderby t.piCode,t.pctFunMeasurand, t.pctFunMeasurand group t by t.piCode into g orderby g.First().piCode,g.First().pctFunMeasurand, g.First().pctFunFunction, g.First().pctFunNumber select g; Linq延迟检索: var ls5 = cc.AsEnumerable(); ls5=ls5.Where(p => p.First().piCode.Split(new char[] { ' ' })[0].ToString() == strPiCode1); 当然,Linq方式虽然在这种非数据库读取数据的处理中会相对比较方便,但效率的确实在不敢恭维,大家有什么更好的方式,共同探讨一下。 其实,今年一直想做这么一个接口开放平台,通过WEB API的方式开放出来,但目前来看貌似有些困难,公司并不允许。。。