EF GroupBy 根据key 分组 再把key求和(取决于每条数据中 arr的条数) arr 中有多少条数据 就把多少个key 加起来
List<A> alist = new List<A>{
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
,b=,c=,d=,e=},
}; //分组求 Key 的和
var alistarr = alist.GroupBy(a => new { a.name, a.a, a.b, a.c, a.d }); // 根据分组(Key) 有7条 // ‘a 为 name a b c d A 也就是A (name a b c d e) 每条里面都是个集合
var selec = alistarr.Select(a => new // a其实是 ‘a 与 A 组合 就是key - arr
{
a.Key.name, //获取 System.Linq.IGrouping<TKey,TElement> 的键。 Element(元素的意思 可以有多个元素)
//所有的Sum 都是要跟在集合后面的 a是 分组后的每条数据 (唯一key value(集合 arr) )
a = a.Sum(p => a.Key.a), // 每一条再求和 p是A (那个集合 arr的每个元素 A) 在这里没有用到
b = a.Sum(p => a.Key.b), // 所以就是 进去 集合 arr的每个元素 A 没用到 返回a.Key.b 就相当于arr中 有多少个元素 就加多少次 a.Key.b
c = a.Sum(p => a.Key.c), // 效果就是key的和 (根据key分组 再分组下(key arr) 取得每条 数据的 key的和) arr 中有多少条数据 就把多少个key 加起来
d = a.Sum(p => a.Key.d),
e = a.Sum(p => p.e), // a是 key - arr 在arr 中求e 的和
s = a.Sum(p => p.a) // a是 key - arr 在arr 中求a 的和 //每个A里面是有a的 上面是 arr长度个 a.Key.a 的和 这里是 arr 中求a 的和 因为分过组 所以arr 中具有相同a 而又都是arr 一个是arr长度 a.Key.a 之和 一个是arr 中a(和 key.a 相同)的和 所以 a和s 相同 一般不会这么写 逻辑混乱
}).ToList();
var alistarr2 = alist.GroupBy(a => new { a.name }).Select(a => new // 5条
{ // key - arr
a.Key.name,
a = a.Sum(p => p.a), // 根据name分组(5条 也可理解5组) 求每组中a的和
b = a.Sum(p => p.b),
c = a.Sum(p => p.c),
d = a.Sum(p => p.d),
e = a.Sum(p => p.e),
});
var alist3 = alist.GroupBy(a => new { a.name, a.a }).Select(a => new
{
a.Key.name,
a = a.Sum(p => p.a),
s = a.Sum(p => a.Key.a)
});
class A
{
public string name { get; set; }
public int a { get; set; }
public int b { get; set; }
public int c { get; set; }
public int d { get; set; }
public int e { get; set; }
}


EF GroupBy 根据key 分组 再把key求和(取决于每条数据中 arr的条数) arr 中有多少条数据 就把多少个key 加起来的更多相关文章
- EF GroupBy 分组 取某条的 总数
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- pandas 取 groupby 后每个分组的前 N 行
原始数据如下: (图是从 excel 截的,最左1行不是数据,是 excel 自带的行号,为了方便说明截进来的) 除去首行是标题外,有效数据为 28行 x 4列 目前的需求是根据 partition ...
- pd.qcut, pd.cut, df.groupby()等在分组和聚合方面的应用
pd.qcut, pd.cut, df.groupby()等在分组和聚合方面的应用 量化交易里, 需要进行大量的分组和统计, 以方便自己处优势的位置/机会. 比如对股价进行趋势分析, 波动性分析, 量 ...
- 我的Android进阶之旅------>解决Jackson、Gson解析Json数据时,Json数据中的Key为Java关键字时解析为null的问题
1.问题描述 首先,需要解析的Json数据类似于下面的格式,但是包含了Java关键字abstract: { ret: 0, msg: "normal return.", news: ...
- 键盘录入一个文件夹路径,统计该文件夹(包含子文件夹)中每种类型的文件及个数,注意:用文件类型(后缀名,不包含.(点),如:"java","txt")作为key, 用个数作为value,放入到map集合中,遍历map集合
package cn.it.zuoye5; import java.io.File;import java.util.HashMap;import java.util.Iterator;import ...
- 利用 groupby apply list 分组合并字符
利用 groupby apply list 分组合并字符 因为需要对数据进行分组和合并字符,找到了以下方法. 有点类似 SQL 的 Group BY. import pandas as pd impo ...
- java8--List转为Map、分组、过滤、求和等操作----代码示例
Java 8 函数式编程风格 Java 迄今为止最令人激动的特征.这些新的语言特征允许采用函数式风格来进行编码,我们可以用这些特性完成许多有趣的功能.这些特性如此有趣以至于被认为是不合理的.他们说会影 ...
- poj 2253 一条路径中的最大边 再找出最小的
题目大意,有两只青蛙,分别在两个石头上,青蛙A想要到青蛙B那儿去,他可以直接跳到B的石头上,也可以跳到其他石头上,再从其他石头跳到B那儿,求青蛙从A到B的所有路径中最小的Frog Distance,我 ...
- MYSQL-实现ORACLE 和SQLserver数据中- row_number() over(partition by ) 分组排序功能
网上看见了好多例子都基本上是一样的,没有过多的解释,对于一个初学MySQL来说有点难,我把部分转摘过来如下 原文:http://www.cnblogs.com/buro79xxd/archive/20 ...
随机推荐
- java实现高性能的数据同步
最近在做一个银行的生产数据脱敏系统,今天写代码时遇到了一个“瓶颈”,脱敏系统需要将生产环境上Infoxmix里的数据原封不动的Copy到另一台 Oracle数据库服务器上,然后对Copy后的数据作些漂 ...
- [Functional Programming] Daggy
const daggy = require('daggy'); const {tagged, taggedSum} = daggy; const Coord = daggy.tagged('Coord ...
- 杂谈:大容量(T级容量)的网盘的意义
这两天,大容量的网盘的消息不断的推出.有百度的网盘推1T容量的:有腾讯的推10T容量的:有的还推不限容量的等等不一而足. 先看看大容量网盘的历史 早先是没有网盘这个概念的.能提供免费空间是电子邮箱 早 ...
- Direct2D教程VII——变换几何(TransformedGeometry)对象
目前博客园中成系列的Direct2D的教程有 1.万一的 Direct2D 系列,用的是Delphi 2009 2.zdd的 Direct2D 系列,用的是VS中的C++ 3.本文所在的 Direct ...
- 【Python】使用torrentParser1.03对多文件torrent的分析结果
Your environment has been set up for using Node.js 8.5.0 (x64) and npm. C:\Users\horn1>cd C:\User ...
- 解决Android sdk无法下载的问题
由于android官网在国内无法正常访问,在安装android sdk时经常会出现http://dl.google.com拒绝访问的情况.为了解决这个问题,建议使用国内镜像源,这里推荐几个: 1.mi ...
- C++ 对象的定义
1.考虑下面的方法void Print(const Student& s){ printf("Student[%s:%d]\n", s._Name.c_str(), s._ ...
- 关于extern "C"(详细剖析)
[目录] 引言 extern “C”的前世今生 小心门后的未知世界 Q&A c++调用c的方法 c调用c++的方法 在你工作过的系统里,不知能否看到类似下面的代码. 这好像没有什么问题,你应该 ...
- vsphere storage appliance工作原理和实施
摘录自:http://www.07net01.com/storage_networking/VMwarexunihuazhiVSA_vSphere_Storage_Appliance_qunji_yi ...
- Linux--U盘安装Ubuntu12.04[转]
http://www.cnblogs.com/plokmju/p/linux_installubuntu.html 最近一直在研究Android内核驱动开发的相关事宜,使用VMware虚拟机虽然可以更 ...