PS2010 - PSI - Как я могу получить отфильтрованный список проектов из PSI?
Как я могу получить отфильтрованный список проектов через PSI? Я пробовал через веб-сервис Project и метод ReadProjectStatus, но там нет функции фильтрации.
Во внутреннем веб-сервисе PWA есть также метод ProjectGetProjectCenterProjectsForGridJson, который на самом деле недокументирован, поэтому его невозможно использовать...
У вас есть идеи, как этого добиться? Есть ли родной способ сделать такую фильтрацию?
Спасибо!
1 ответ
Вы можете использовать фильтр запроса.
private static Guid EnsureEnterpriseProject(string ProjectName)
{
SvcProject.ProjectDataSet ProjectDs = new SvcProject.ProjectDataSet();
PSLibrary.Filter ProjectFilter = new Microsoft.Office.Project.Server.Library.Filter();
ProjectFilter.FilterTableName = ProjectDs.Project.TableName;
ProjectFilter.Fields.Add(new PSLibrary.Filter.Field(ProjectFilter.Project.TableName, ProjectFilter.Project.[Give column Name].ColumnName, PSLibrary.Filter.SortOrderTypeEnum.None));
ProjectFilter.Fields.Add(new PSLibrary.Filter.Field(ProjectFilter.Project.TableName, ProjectFilter.Project.[Give column Name].ColumnName, PSLibrary.Filter.SortOrderTypeEnum.None));
ProjectFilter.Fields.Add(new PSLibrary.Filter.Field(ProjectFilter.Project.TableName, ProjectFilter.Project.[Give column Name].ColumnName, PSLibrary.Filter.SortOrderTypeEnum.None));
ProjectFilter.Fields.Add(new PSLibrary.Filter.Field(ProjectFilter.Project.TableName, ProjectFilter.Project.[Give column Name].ColumnName, PSLibrary.Filter.SortOrderTypeEnum.None));
PSLibrary.Filter.FieldOperator existingProject = new PSLibrary.Filter.FieldOperator(PSLibrary.Filter.FieldOperationType.Equal, ProjectDs.Project.[Give Column Name].ColumnName, ProjectName);
projecteFilter.Criteria = existingProject;
string filterXml = ProjectFilter.GetXml();
ProjectDs = ServiceContext.Current.PSI.ProjectService.ReadProject(filterXml, false);
if (ProjectDs.Project.Count >= 1)
{
//Get the desired value from the dataset.
}
return Valuegotfromdataset;
}