gpt4 book ai didi

c# - 如何使此 LINQ 查询更快?

转载 作者:行者123 更新时间:2023-11-30 15:23:54 24 4
gpt4 key购买 nike

modelData 在列表中有 100,000 个项目。

我在 2 个循环中执行 2 个“选择”。

是否可以采用不同的结构 - 因为需要很长时间 - 10 分钟

public class ModelData
{
public string name;
public DateTime DT;
public int real;
public int trade;
public int position;
public int dayPnl;
}

List<ModelData> modelData;

var dates = modelData.Select(x => x.DT.Date).Distinct();
var names = modelData.Select(x => x.name).Distinct();

foreach (var aDate in dates)
{
var dateRealTrades = modelData.Select(x => x)
.Where(x => x.DT.Date.Equals(aDate) && x.real.Equals(1));

foreach (var aName in names)
{
var namesRealTrades = dateRealTrades.Select(x => x)
.Where(x => x.name.Equals(aName));

// DO MY PROCESSING
}
}

最佳答案

我相信您可以通过使用 group by 的两个查询来实现您想要的。一个按日期创建查找,另一个为您提供名称-日期分组项目。

var data = modelData.Where(x => x.real.Equals(1))
.GroupBy(x => new { x.DT.Date, x.name });
var byDate = modelData.Where(x => x.real.Equals(1))
.ToLookup(x => x.DT.Date);

foreach(var item in data)
{
var aDate = item.Key.Date;
var aName = item.Key.name;
var namesRealTrades = item.ToList();
var dateRealTrades = byDate[aDate].ToList();

// DO MY PROCESSING
}

第一个查询将为您提供按名称和日期分组的项目以进行迭代,第二个查询将为您提供查找以获取与给定日期关联的所有项目。第二个使用查找,以便列表迭代一次并让您快速访问生成的项目列表。

这应该会大大减少您从当前拥有的 modelData 迭代的次数。

关于c# - 如何使此 LINQ 查询更快?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33782069/

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