标题:【求助】筛选数据
只看楼主
venomlk
Rank: 2
等 级:论坛游民
威 望:1
帖 子:14
专家分:85
注 册:2009-2-18
结帖率:100%
已结贴  问题点数:20 回复次数:3 
【求助】筛选数据
有一个list<自定义结构>,结构中包括“年级、班级、姓名、语文成绩、数学成绩、物理成绩、化学成绩、历史成绩、体育成绩,总分”
想实现的是:最好利用linq一次性筛选出各年级、各班级中总分前十名的明细,并且明细以年级、班级、总分降序排序(各科成绩的字段也需要保留,换句话说就是,在list中的明细以年级、班级、总分进行排序,把各年级、班级前十的数据留下,其它删掉)
大概语句类似:list.groupby(l...........).take(10)

谢谢各位老师!
搜索更多相关主题的帖子: 数据 总分 成绩 筛选 list 
2021-09-13 18:36
qq2889577966
Rank: 4
等 级:业余侠客
威 望:5
帖 子:57
专家分:267
注 册:2021-4-14
得分:20 
把全部人按规则个排序,输出到列表,取不同年级和班级的前几个,那个Group忘了,就用循环判断了
应该是
var Result_List = Infos.OrderByDescending(r => r.Result_Total).OrderBy(c => c.Classes_Id).OrderBy(g => g.Grade_Id).ToList().GroupBy(。。。。。什么的)


程序代码:
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Windows.Forms;

namespace Test_2
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }


        public class Info
        {
            public int Grade_Id; // 年级Id值
            public int Classes_Id; // 班级Id值
            public string Grade; // 年级名称
            public string Classes; // 班级名称
            public string Name; // 姓名
            public double Result_1; // 成绩1
            public double Result_2; // 成绩2
            public double Result_Total; // 总成绩
            public Info(int g_id, int c_id, string g, string c, string n, double r1, double r2)
            {
                Grade_Id = g_id;
                Classes_Id = c_id;
                Grade = g;
                Classes = c;

                Name = n;
                Result_1 = r1;
                Result_2 = r2;
                Result_Total = r1 + r2;
            }
        }
        public static List<Info> Infos = new List<Info>();


        private void button1_Click(object sender, EventArgs e)
        {
            Infos.Add(new Info(0, 0, "一年级", "一班", "AA", 10.0, 10.0));
            Infos.Add(new Info(0, 0, "一年级", "一班", "BB", 9.0, 9.0));
            Infos.Add(new Info(0, 0, "一年级", "一班", "CC", 8.0, 8.0));
            Infos.Add(new Info(0, 1, "一年级", "二班", "EE", 6.0, 6.0));
            Infos.Add(new Info(0, 1, "一年级", "二班", "FF", 5.0, 6.0));
            Infos.Add(new Info(0, 1, "一年级", "二班", "DD", 11.0, 11.0));

            Infos.Add(new Info(1, 1, "二年级", "二班", "QQ", 5.0, 5.0));
            Infos.Add(new Info(1, 1, "二年级", "二班", "PP", 7.0, 7.0));
            Infos.Add(new Info(1, 1, "二年级", "二班", "RR", 6.0, 6.0));
            Infos.Add(new Info(1, 0, "二年级", "一班", "KK", 10.0, 10.0));
            Infos.Add(new Info(1, 0, "二年级", "一班", "MM", 9.0, 9.0));
            Infos.Add(new Info(1, 0, "二年级", "一班", "OO", 8.0, 8.0));


            // 全部人先按照年级、班级、总分排序
            var Result_List = Infos.OrderByDescending(r => r.Result_Total).OrderBy(c => c.Classes_Id).OrderBy(g => g.Grade_Id).ToList();
            // 全部排序出来了,按顺序取不同年级和班级的前几个就可以了,写个循环判断就可以了
            for (int i = 0; i < Result_List.Count; i++)
            {
                richTextBox1.AppendText("年级:" + Result_List[i].Grade + "  班级:" + Result_List[i].Classes + "  姓名:" + Result_List[i].Name + "  成绩1:" + Result_List[i].Result_1 + "  成绩2:" + Result_List[i].Result_2 + "  总分:" + Result_List[i].Result_Total + "\r");
            }

        }
    }
}

2021-09-14 13:55
venomlk
Rank: 2
等 级:论坛游民
威 望:1
帖 子:14
专家分:85
注 册:2009-2-18
得分:0 
多谢qq2889577966版主的回复!
程序中其它的条件筛选都是用linq实现的,只差这一个,所以也想用linq来实现(可能有点儿强迫症),呵呵
再次多谢qq2889577966版主的关注!
2021-09-15 08:52
qq2889577966
Rank: 4
等 级:业余侠客
威 望:5
帖 子:57
专家分:267
注 册:2021-4-14
得分:0 
只能取每个年级和班级的第一名只能用First(),取10个咋取呢??有知道的说下
var Result_List = Infos.OrderByDescending(r => r.Result_Total).OrderBy(c => c.Classes_Id).OrderBy(g => g.Grade_Id).GroupBy(p => new { p.Grade, p.Classes }).Select(x => x.First()).ToList();


[此贴子已经被作者于2021-9-15 12:03编辑过]

2021-09-15 11:58



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-506835-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.106339 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved