如何在linq中统计多级列表中的所有项目
本文关键字:项目 列表 统计 linq 多级 | 更新日期: 2023-09-27 18:00:31
我有类似的多级列表
public class Rd {
public List<Ru> Ru = new List<Ru>();
}
public class Ru {
public List<Rc> Rc = new List<Rc>();
}
public class Rc {
public List<Rcp> Rcp = new List<Rcp>();
}
public class Rcp {
public string Bn { get; set; }
}
如何使用linq统计此多级列表中的所有项目
在这种情况下,linq和foreach之间哪个更好
您可能想检查这个嵌套列表中有多少字符串?
List<Rd> a = YourList;
int count =
(from rd in a // foreach (Rd rd in a)
from ru in rd.Ru // foreach (Ru ru in rd.Ru)
from rc in ru.Rc // foreach (Rc rc in ru.Rc)
from rcp in rc.Rcp // foreach (Rcp rcp in rc.Rcp)
select rcp) // select rcp`s
.Count(rcp => rcp.Bn != null); // Count if rcp != null
但是,如果你也想计算列表,你必须使用这个。
int countAll = a.Sum(rd =>
rd.Ru.Sum(ru =>
ru.Rc.Sum(rc =>
rc.Rcp.Count(rcp =>
rcp.Bn != null) + 1) + 1) + 1);
我翻转了+
操作数,所以它可能更清晰。
你必须为你查看的每个列表添加1。因此:
int countAll = a.Sum(rd => // foreach (Rd rd in a) add 1 to next Sum
1 + rd.Ru.Sum(ru => // foreach (Ru ru in rd.Ru) add 1 to next Sum
1 + ru.Rc.Sum(rc => // foreach (Rc rc in ru.Rc) add 1 to next Count
1 + rc.Rcp.Count(rcp => // Count rcp`s if rcp != null
rcp.Bn != null))));
如果你学会了这个算法,你可以添加更多的自我列表。
如果您的意思是计算Rd中的所有Bn,请使用SelectMany()
:
rd.SelectMany(z => Ru).SelectMany(z => Rc).SelectMany(z => Rcp).Count()
如果您还需要检查字符串不是null或空的所有实例
Rd pack = new Rd();
int x = pack.Ru.Sum(node => node.Rc.Sum(cnode => cnode.Rcp.Count(ccnode => !String.IsNullOrWhiteSpace(ccnode.Bn))));