EPLAN API 入门系列PPE

最近两个月,断断续续完成了一个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的方式开放出来,但目前来看貌似有些困难,公司并不允许。。。
原文地址:https://www.cnblogs.com/AriLee/p/2810286.html