Ниже приведен пример использования операции OpenWbk для открытия рабочей книги с заданием периода отображения данных. В запросе передаются: экземпляр рабочей книги и период, который необходимо установить. В ответе приходит моникёр открытого экземпляра рабочей книги.
{
"OpenWbk" :
{
"tOb" :
{
"id" : "S1!M!5505"
},
"tArg" :
{
"args" :
{
"openForEdit" : "true"
},
"metaGet" :
{
"obInst" : "true",
"useGridAutoAdjust" : "true",
"period" : "true"
},
"metaSet" :
{
"pattern" :
{
"obInst" : "true",
"useGridAutoAdjust" : "true",
"period" : "true"
},
"meta" :
{
"period" :
{
"start" : "1995-01-01",
"end" : "2015-01-01"
}
},
"metaGet" :
{
"obInst" : "true",
"useGridAutoAdjust" : "true",
"period" : "true"
}
}
}
}
}
{
"OpenWbkResult" :
{
"id" :
{
"id" : "S1!M!S!W3"
},
"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" : "0",
"windowsPosition" : "Vertical",
"hasPivot" : "0",
"hasLaner" : "1",
"series" :
{
"@count" : "3",
"its" : ""
},
"period" :
{
"start" : "1995-01-01",
"end" : "2015-01-01"
}
},
"metaSet" :
{
"id" :
{
"id" : "S1!M!S!W3"
},
"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" : "0",
"windowsPosition" : "Vertical",
"hasPivot" : "0",
"hasLaner" : "1",
"series" :
{
"@count" : "3",
"its" : ""
},
"period" :
{
"start" : "1995-01-01",
"end" : "2015-01-01"
}
}
}
}
}
public static OpenWbkResult OpenWbkForEdit(MbId mb, string wbkId)
{
var tWbk = new OpenWbk()
{ // Задаём параметры выполнения операции
tArg = new OpenWbkArg()
{// Указываем, что открываем рабочую книгу для редактирования
args = new WbkOpenArgs()
{
openForEdit = true
},// Задаём шаблон извлечения данных
metaGet = new WbkMdPattern()
{
period = true
},// Задаём параметры изменения данных
metaSet = new SetWbkMdArg()
{ // Задаём шаблон изменения данных
pattern = new WbkMdPattern()
{
period = true
},// Задаём изменяемые данные
meta = new WbkMd()
{// Задаём параметры изменения периода отображения
period = new LnPeriod()
{
start = DateTime.Parse("01.01.1995"),
end = DateTime.Parse("01.01.2015")
}
},// Задаём шаблон извлечения изменённых данных
metaGet = new WbkMdPattern()
{
period = true
}
}
},// Указываем рабочую книгу, с которой Выполнение операции
tOb = new OdId() { id = mb.id + "!" + FindObjectById(mb, wbkId).k }
};
// Создаем прокси-объект для выполнения операции
var somClient = new SomPortTypeClient();
// Выполнение операции
var tResult = somClient.OpenWbk(tWbk);
Console.WriteLine("Изменена рабочая книга: " + tResult.id.id);
LnPeriod period = tResult.meta.period;
Console.WriteLine("Прежний период отображения данных:");
Console.WriteLine("".PadRight(3) + "- начало: " + period.start.ToShortDateString());
Console.WriteLine("".PadRight(3) + "- окончание: " + period.end.ToShortDateString());
period = tResult.metaSet.meta.period;
Console.WriteLine("Новый период отображения данных:");
Console.WriteLine("Прежний период отображения данных:");
Console.WriteLine("".PadRight(3) + "- начало: " + period.start.ToShortDateString());
Console.WriteLine("".PadRight(3) + "- окончание: " + period.end.ToShortDateString());
return tResult;
}
См. также: