gpt4 book ai didi

c# - 嵌套 groupby LINQ to treeview

转载 作者:行者123 更新时间:2023-11-30 22:32:01 26 4
gpt4 key购买 nike

我有以下格式的列表:

List<Amortizacion> lista = new List<Amortizacion>
{
new Amortizacion {Fecha=Convert.ToDateTime("20/01/2012"), Idbanco=1, Nbanco="Bancomer", Idgrupo=1, Ngrupo="Jorge", Npersona="Jorge", Monto=500m},
new Amortizacion {Fecha=Convert.ToDateTime("20/01/2012"), Idbanco=2, Nbanco="Afirme", Idgrupo=2, Ngrupo="CreaB", Npersona="Noe", Monto=200m},
new Amortizacion {Fecha=Convert.ToDateTime("20/01/2012"), Idbanco=2, Nbanco="Afirme", Idgrupo=2, Ngrupo="CreaB", Npersona="Julio", Monto=250m},
new Amortizacion {Fecha=Convert.ToDateTime("20/01/2012"), Idbanco=2, Nbanco="Afirme", Idgrupo=2, Ngrupo="CreaB", Npersona="Marcela", Monto=300m},
new Amortizacion {Fecha=Convert.ToDateTime("21/01/2012"), Idbanco=1, Nbanco="Bancomer", Idgrupo=3, Ngrupo="Pedro", Npersona="Pedro", Monto=150m},
new Amortizacion {Fecha=Convert.ToDateTime("21/01/2012"), Idbanco=1, Nbanco="Bancomer", Idgrupo=4, Ngrupo="CBI", Npersona="Juan", Monto=400m},
new Amortizacion {Fecha=Convert.ToDateTime("21/01/2012"), Idbanco=1, Nbanco="Bancomer", Idgrupo=4, Ngrupo="CBI", Npersona="Manuel", Monto=450m},
new Amortizacion {Fecha=Convert.ToDateTime("22/01/2012"), Idbanco=2, Nbanco="Afirme", Idgrupo=5, Ngrupo="Pepe", Npersona="Pepe", Monto=300m},
};

并以这种方式定义我的类:

class Amortizacion
{
public DateTime Fecha { get; set; }
public int Idgrupo { get; set; }
public string Ngrupo { get; set; }
public int Idbanco { get; set; }
public string Nbanco { get; set; }
public string Npersona { get; set; }
public decimal Monto { get; set; }
}

而且我想实现一个嵌套的groupby来显示在一个treeview控件中。首先,我需要按 Fecha 分组,然后按 Idbanco,最后按 Idgrupo。我正在寻找的结果是这样的:

  • 20/01/2012 (4) 学分
    • 银行家
      • 豪尔赫 500
    • 肯定
      • CreaB 750
        • No 200
        • 胡里奥 250
        • 马塞拉 300
  • 21/01/2012 (3) 学分
    • 银行家
      • 佩德罗 150
      • CBI 850
        • 400 卷
        • 曼纽尔 450
  • 22/01/2012 (1) 学分
    • 肯定
      • 佩佩 300

请注意,在“Fecha”节点中,括号之间的数字是分组依据的字段数,而在“Idgrupo”节点中,显示的数量是单个“Monto”的总和。

到目前为止我已经编码了

var gpoFecha = lista.GroupBy(g => g.Fecha);
int ifecha = 0;
foreach (var fecha in gpoFecha)
{
TreeNode nodoFecha = new TreeNode(fecha.Key.ToString());
treeAm.Nodes.Add(nodoFecha);
var gpoBanco = fecha.GroupBy(gp => gp.Idbanco);
foreach (var banco in gpoBanco)
{
int ibanco = 0;
TreeNode nodoBanco = new TreeNode(banco.Key.ToString());
treeAm.Nodes[ifecha].Nodes.Add(nodoBanco);
var gpoGrpo = banco.GroupBy(gpo => gpo.Idgrupo);
foreach (var cred in gpoGrpo)
{
TreeNode nodoCred = new TreeNode(cred.Key.ToString());
treeAm.Nodes[ifecha].Nodes[ibanco].Nodes.Add(nodoCred);
}
ibanco++;
}
ifecha++;
}

问题是我的代码没有按预期工作。另一个问题是,我不知道如何在我的树节点中不仅显示 key ,还不知道如何显示定义该 key 的字符串(我的意思是 IdBanco=1 必须显示 Nbanco="Bancomer",就像我在上面显示的那样。)。

另一个有趣的问题:这是最有效的方法吗?谢谢

最佳答案

var query = from l in lista
group l by l.Fecha into fetchaGroup
select new
{
Fecha = fetchaGroup.Key,
Count = fetchaGroup.Count()
,FetchaGroup = (from fg in fetchaGroup
group fg by fg.Nbanco into NbancoGroup
select new
{
Nbanco = NbancoGroup.Key,
NbancoGroup = (from ng in NbancoGroup
group ng by ng.Ngrupo into NgrupoGroup
select new { Ngrupo = NgrupoGroup.Key, NgrupoGroup }
)
}
)
}
;


foreach (var g in query)
{
Console.WriteLine("{0} ({1})", g.Fecha, g.Count);

foreach (var fg in g.FetchaGroup)
{
Console.WriteLine("\t{0}", fg.Nbanco);

foreach (var ng in fg.NbancoGroup)
{
Console.WriteLine("\t\t{0} {1}", ng.Ngrupo, ng.NgrupoGroup.Sum(ngg => ngg.Monto));

if (ng.NgrupoGroup.Count() > 1)
{
foreach (var ngg in ng.NgrupoGroup)
{
Console.WriteLine("\t\t\t{0} {1}", ngg.Npersona, ngg.Monto);
}
}
}
}
}

关于c# - 嵌套 groupby LINQ to treeview,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8945694/

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