решил сделать это с получателем событий и хотел бы поделиться кодом, если у кого-то есть подобное требование.Приемник событий позволяет легко получить сумму столбца и получить процент для каждой строки.см. код для события ItemAdded, но вы хотели бы добавить один и тот же код для события ItemUpdated и ItemDeleted, чтобы оно соответствующим образом отражало обновление.
public override void ItemAdded(SPItemEventProperties properties)
{
base.ItemAdded(properties);
string listName = "your list name goes here";
using (SPWeb web = properties.OpenWeb())
{
if (web.Lists[listName] != null)
{
try
{
SPList splist = web.Lists[listName];
int sum = 0;
foreach (SPListItem item in splist.Items)
{
sum = sum + Convert.ToInt32(item["Values"]);
}
//LoggingService
foreach (SPListItem item in splist.Items)
{
string percentage = string.Empty;
int percent = Convert.ToInt32(item["Values"]);/// Convert.ToInt32(sum);
double questient = (double)percent / sum;
percentage = questient.ToString("P1", CultureInfo.InvariantCulture);
item["Percent & widget"] = percentage;
this.EventFiringEnabled = false;
item.Update();
this.EventFiringEnabled = true;
}
}
catch (Exception ex)
{
// LoggingService
}
} // end if
} // end using
}