1 /*计算合计和累计*/
2
3 List<数据> 存储过程 = new List<数据>();
4 存储过程.Add(new 数据 { 年段 = 1, 分数 = 59, 姓名 = "浪子燕青",学号 = "104" });
5 存储过程.Add(new 数据 { 年段 = 1, 分数 = 100, 姓名 = "及时雨宋",学号 = "101" });
6 存储过程.Add(new 数据 { 年段 = 2, 分数 = 89.44, 姓名 = "智多星吴",学号 = "201" });
7 存储过程.Add(new 数据 { 年段 = 2, 分数 = 70, 姓名 = "小旋风李",学号 = "202" });
8 存储过程.Add(new 数据 { 年段 = 1, 分数 = 80, 姓名 = "行者武松",学号 = "102" });
9 存储过程.Add(new 数据 { 年段 = 2, 分数 = 90, 姓名 = "花和尚鲁",学号 = "203" });
10 存储过程.Add(new 数据 { 年段 = 3, 分数 = 50, 姓名 = "黒旋风李",学号 = "301" });
11 存储过程.Add(new 数据 { 年段 = 3, 分数 = 100, 姓名 = "青面兽杨",学号 = "301" });
12 存储过程.Add(new 数据 { 年段 = 3, 分数 = 100, 姓名 = "混江龙李",学号 = "302" });
13 存储过程.Add(new 数据 { 年段 = 1, 分数 = 87, 姓名 = "母大虫顾",学号 = "103" });
14
15
16 List<数据> 最终结果 = new List<数据>();
17
18 List<int> 年段集合 = 存储过程.GroupBy(p => p.年段).Select(p => p.Key).ToList();
19
20 foreach (var item in 年段集合)
21 {
22 List<数据> 临时集合 = new List<数据>();
23
24 临时集合.AddRange(存储过程.Where(p => p.年段 == item));
25
26 临时集合 = 临时集合.OrderBy(p => p.学号).ToList();
27
28 临时集合.Add(new 数据 { 学号 = "合计", 分数 = 临时集合.Sum(p => p.分数), 年段 = 999, 姓名 = "" });
29
30 double 这一次的累计结果 = 临时集合.Where(p => p.学号 == "合计").Sum(p => p.分数);
31 double 上一次的累计结果 = 最终结果.Where(p => p.学号 == "合计").Sum(p => p.分数);
32
33 double sum = 上一次的累计结果 + 这一次的累计结果;
34
35 临时集合.Add(new 数据 { 学号 = "累计", 分数 = sum, 年段 = 999, 姓名 = "" });
36 最终结果.AddRange(临时集合);
37 临时集合.Clear();
38 }
39
40 string json = Newtonsoft.Json.JsonConvert.SerializeObject(最终结果);//序列化结果
41 File.WriteAllText("d:\\1.json", json);