Ниже приведен пример использования операции SetWbkMd для преобразования значений ряда. В запросе передаются: экземпляр открытой рабочей книги, шаблон изменения данных, параметры преобразования ряда и шаблон извлечения изменённых данных. В ответе приходит описание рядов в рабочей книге.
{
"SetWbkMd" :
{
"tWbk" :
{
"id" : "S1!M!S!W12"
},
"tArg" :
{
"refresh" : "",
"pattern" :
{
"obInst" : "false",
"useGridAutoAdjust" : "true",
"series" : "Change",
"seriesDisplayParams" : "true"
},
"meta" :
{
"series" :
{
"its" :
{
"it" :
[
{
"k" : "2",
"id" : "OBJ2",
"n" : "USA|A",
"vis" : "true",
"kind" : "Calculate",
"dependencies" : "",
"selectedUnit" : "",
"displayParams" :
{
"inversion" : "Diff",
"inversionLag" : "PrecidingYear",
"previousInversionLag" : "3",
"setDefault" : "false"
},
"tag" : "",
"hasChildren" : "false",
"index" : "0",
"expanded" : "false",
"level" : "Year",
"childrenCount" : "0",
"visibleChildrenCount" : "0",
"flags" : "0"
}
]
}
}
},
"metaGet" :
{
"obInst" : "true",
"title" : "false",
"useGridAutoAdjust" : "true",
"series" : "Get",
"seriesDependencies" : "false",
"seriesDependents" : "false",
"seriesAtts" : "false",
"seriesPrimaryAttsForEmpty" : "false",
"seriesDisplayParams" : "false"
}
}
}
}
{
"SetWbkMdResult" :
{
"refresh" : "",
"id" :
{
"id" : "S1!M!S!W12"
},
"meta" :
{
"obInst" :
{
"obDesc" :
{
"@ds" : "",
"@isShortcut" : "0",
"@isLink" : "0",
"@ver" : "2",
"@hf" : "0",
"i" : "WBK_AD",
"n" : "Годовые данные",
"k" : "5505",
"c" : "2827",
"p" : "5471",
"h" : "0",
"hasPrv" : "0",
"ic" : "0",
"trackElementDependents" : "0",
"isPermanent" : "1",
"isTemp" : "0"
}
},
"dirty" : "1",
"windowsPosition" : "Vertical",
"hasPivot" : "0",
"hasLaner" : "1",
"series" :
{
"@count" : "3",
"its" :
{
"it" :
[
{
"k" : "2",
"id" : "OBJ2",
"n" : "USA|A",
"vis" : "1",
"kind" : "Calculate",
"selectedUnit" : "",
"tag" : "",
"hasChildren" : "0",
"index" : "0",
"expanded" : "0",
"level" : "Year",
"childrenCount" : "0",
"visibleChildrenCount" : "0",
"flags" : "0"
},
{
"k" : "4",
"id" : "OBJ4",
"n" : "Canada|A",
"vis" : "1",
"kind" : "Calculate",
"selectedUnit" : "",
"tag" : "",
"hasChildren" : "0",
"index" : "1",
"expanded" : "0",
"level" : "Year",
"childrenCount" : "0",
"visibleChildrenCount" : "0",
"flags" : "0"
},
{
"k" : "6",
"id" : "OBJ6",
"n" : "Russia|A",
"vis" : "1",
"kind" : "Calculate",
"selectedUnit" : "",
"tag" : "",
"hasChildren" : "0",
"index" : "2",
"expanded" : "0",
"level" : "Year",
"childrenCount" : "0",
"visibleChildrenCount" : "0",
"flags" : "0"
}
]
},
"displayDataAs" : "CalculatedValues",
"autoRecalc" : "1",
"createDerivedSeries" : "Default",
"permanentData" : "0"
}
}
}
}
public static SetWbkMdResult SetWbkTransformSerie(WbkId wbkId, WbkMd wbk)
{
if (!wbk.hasLaner.Value) { return null; };
// Поулчаем 1-й ряд в рабочей книге
LnSerie transfSerie = wbk.series.its.GetValue(0) as LnSerie;
// Задаём параметры преобразования значений ряда
transfSerie.displayParams = new LnSerieDisplayParams();
LnSerieDisplayParams par = transfSerie.displayParams;
par.inversion = TsInversionType.Diff;
par.inversionLag = TsInversionLag.PrecidingYear;
par.previousInversionLag = 3;
par.setDefault = false;
// Задаём параметры выполнения операции
var tOp = new SetWbkMd
{ // Указываем изменяемую рабочую книгу
tWbk = wbkId,
tArg = new SetWbkMdArg()
{ // Задаём шаблон изменения данных
pattern = new WbkMdPattern()
{
obInst = false,
series = ListOperation.Change,
seriesDisplayParams = true
},// Задаём параметры изменения данных
meta = new WbkMd()
{ // Задаём параметры преобразования данных
series = new LnSeries()
{
its = new LnSerie[]{transfSerie}
}
},
refresh = new EaxRefresh { },
// Задаем шаблон извлечения изменённых данных
metaGet = new WbkMdPattern
{
title = false,
series = ListOperation.Get,
seriesAtts = false,
seriesPrimaryAttsForEmpty = false,
seriesDependencies = false,
seriesDependents = false,
seriesDisplayParams = false
}
}
};
// Создаем прокси-объект для выполнения операции
var somClient = new SomPortTypeClient();
// Выполнение операции
var sRes = somClient.SetWbkMd(tOp);
return sRes;
}
См. также: