gpt4 book ai didi

c# - 使用 LINQ 循环和更新集合中的对象值

转载 作者:太空宇宙 更新时间:2023-11-03 13:16:29 24 4
gpt4 key购买 nike

我想遍历集合中的每个对象,然后用另一个数组集合更新每个对象的属性

我的用例是我有一些实体,我最初从我的集合中读取到一个数组中,并执行一些复杂的计算,然后更新回我的原始集合。

public void WhatIfCalculation(string Product, string SiteID, System.Linq.IQueryable<DAL.OMS_StockStatus> prodStatus, ref System.Linq.IQueryable<PivotViewModel> activityInfo)
{
var sff = activityInfo.Where(a => a.Activity == "System Forecast" && a.SiteID == SiteID).ToList();

aSFF = new double?[sff.Count()];
for (int i = 0; i < sff.Count(); i++)
{
aSFF[i] = sff.ElementAt(i).Value + 1;
}

var prf = activityInfo.Where(a => a.Activity == "Planned Receipts" && a.SiteID == SiteID).ToList();
aPRF = new double?[prf.Count()];
for (int i = 0; i < prf.Count(); i++)
{
aPRF[i] = prf.ElementAt(i).Value + 2;
}

// Will perform some calculation here. And then update back my collection.

for (int i = 0; i < aSFF.Length; i++)
{
activityInfo.Where(a => a.Activity == "System Forecast" && a.SiteID == SiteID).ToList().ElementAt(i).Value = aSFF[i];
}

for (int i = 0; i < aPRF.Length; i++)
{
activityInfo.Where(a => a.Activity == "Planned Receipts" && a.SiteID == SiteID).ToList().ElementAt(i).Value = aPRF[i];
}
}

但是上面的更新并没有更新我的收藏。当我浏览我的 activityInfo 时 - 它仍然显示原始值。

最佳答案

尝试以下操作:

public void WhatIfCalculation(string Product, string SiteID, List<DAL.OMS_StockStatus> prodStatus, List<PivotViewModel> activityInfo)
{
var sff = activityInfo.Where(a => a.Activity == "System Forecast"); // Do this in the calling function >> .Where(a => a.SiteID == SiteID).ToList();

aSFF = new double?[sff.Count()];
for (var i = 0; i < sff.Count(); i++)
{
aSFF[i] = sff.ElementAt(i).Value + 1;
}

var prf = activityInfo.Where(a => a.Activity == "Planned Receipts");
aPRF = new double?[prf.Count()];
for (var i = 0; i < prf.Count(); i++)
{
aPRF[i] = prf.ElementAt(i).Value + 2;
}

// Will perform some calculation here. And then update back my collection.

for (var i = 0; i < aSFF.Length; i++)
{
sff.ElementAt(i).Value = aSFF[i];
}

for (var i = 0; i < aPRF.Length; i++)
{
prf.ElementAt(i).Value = aPRF[i];
}
}

如您所见,我向该方法发送了一个列表而不是 IQueryable。原因是 IQueryable 实际上是一个查询语句,而不是记录本身。

基本上,您正在做的是向您用来选择项目并更改它们的方法发送查询。实际项目没有改变。

使用下面的示例,您将发送实际项目的列表。然后可以更改这些项目。我还从您的方法中删除了一些双选语句以提高速度。

这也应该有用:Differences between IQueryable, List, IEnumerator?

关于c# - 使用 LINQ 循环和更新集合中的对象值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25898646/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com