首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

问与答62: 如何按指定个数在Excel中获得一列数据的所有可能组合?

excelperfect Q:数据放置在列A中,我要得到这些数据中任意3个数据的所有可能组合。如下图1所示,列A中存放了5个数据,要得到这5个数据中任意3个数据的所有可能组合,如列B中所示。...如何实现? ? 图1 (注:这是无意在ozgrid.com中看到的一个问题,我觉得程序编写得很巧妙,使用了递归的方法来解决,非常简洁,特将该解答稍作整理后辑录于此与大家分享!)...Dim n AsLong Dim vElements As Variant Dim lRow As Long Dim vResult As Variant '要组合的数据在当前工作表的列...lRow = lRow + 1 Range("B" & lRow) = Join(vResult, ", ") '每组组合放置在多列中...代码的图片版如下: ? 如果将代码中注释掉的代码恢复,也就是将组合结果放置在多列中,运行后的结果如下图2所示。 ? 图2

5.6K30

Entity Framework 的一些性能建议

只选择某列或某些列 有些时候,在C#里写LINQ虽然看着舒服,但性能不一定好,所以有必要做一些调整。...(postId).Hits; 我期待着他们只去数据库里筛选Hits这一列的数据,然而,通过SQL Profiler会发现,这两条语句居然把全部列都给select出来了,访问Hits的操作实际是在内存中进行的...虽然小表看不出性能问题,但万一你的表里有一列是存文件字节流(byte)的,那这样的操作可能会很慢,并且消耗额外的网络传输,所以不能忽视这个问题。...,然后用这个Category的Id去找它所有的Post,最后做Count的其实是.NET在内存里进行的。...紧跟其后的“.Posts”是Category对象的导航属性,EF会用lazy load去加载这个category所有的post,所以就生成了第二条SQL语句。

1.7K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    本人为巨杉数据库(开源NoSQL)写的C#驱动,支持Linq,全部开源,已提交github

    四、关于SequoiaDB的C#驱动      SequoiaDB官方提供C、C++、JAVA、C#、php、Python驱动以及REST架构风格的接口,据官方的说法是Java的驱动很成熟,但是C#的驱动很简单...五、完善改造SequoiaDB的C#驱动      即然官方的驱动太简单,不支持对象处理,也不支持Linq,很不科学,那么应该怎么办呢,其实第一个观点当然是放弃,我们原本使用MongoDB跑的好好的,为什么要给自己找事呢...那么如何来写呢,当然是他山之石,可以攻玉,因为之前做MongoDB开发,原始的驱动配置我们的ORM跑起来也有一些问题,最早我们使用的非MongoDB的官方驱动,而是第三方驱动samus,不支持Decimal...C#对象的方案和支持Linq进行查询、修改、删除的功能。     ...,或者说,更希望自己的医疗系统能够在业务上同时支持MongoDB和SequoiaDB,达到使用环境之中不管是选择MongoDB还是选择SequoiaDB都是同样的代码,为此,我们在AgileEAS.NET

    1.6K00

    本人为巨杉数据库(开源NoSQL)写的C#驱动,支持Linq,全部开源,已提交github

    四、关于SequoiaDB的C#驱动      SequoiaDB官方提供C、C++、JAVA、C#、php、Python驱动以及REST架构风格的接口,据官方的说法是Java的驱动很成熟,但是C#的驱动很简单...五、完善改造SequoiaDB的C#驱动      即然官方的驱动太简单,不支持对象处理,也不支持Linq,很不科学,那么应该怎么办呢,其实第一个观点当然是放弃,我们原本使用MongoDB跑的好好的,为什么要给自己找事呢...那么如何来写呢,当然是他山之石,可以攻玉,因为之前做MongoDB开发,原始的驱动配置我们的ORM跑起来也有一些问题,最早我们使用的非MongoDB的官方驱动,而是第三方驱动samus,不支持Decimal...C#对象的方案和支持Linq进行查询、修改、删除的功能。     ...,或者说,更希望自己的医疗系统能够在业务上同时支持MongoDB和SequoiaDB,达到使用环境之中不管是选择MongoDB还是选择SequoiaDB都是同样的代码,为此,我们在AgileEAS.NET

    2.5K80

    并行爬虫和数据清洗工具(开源)

    C#版本原理 鉴于博客园不少读者熟悉C#,我们不妨先用C#的例子来讲解: 其本质是动态组装Linq, 其数据链为IEnumerable。...Linq的Select函数能够对流进行变换,在本例中,就是对字典不同列的操作(增删改),不同的模块定义了一个完整的Linq流: result= source.Take(mount).where(d=>module0...Python版本原理 python的生成器类似于C#的Linq,是一种流式迭代。...可以将所有的模块分为四种类型: 生成器(GE):如生成100个字典,键为1-100,值为‘1’到‘100’ 转换器(TF):如将地址列中的数字提取到电话列中 过滤器(FT):如过滤所有某一列的值为空的的字典...:如何采集所有二手房数据呢?

    2.5K40

    C#各版本新增加功能(系列文章)

    5.0 版是C#语言有针对性的一个版本。 对此版本中所做的几乎所有工作都归入另一个突破性语言概念:适用于异步编程的 async 和 await 模型。...我们通常认为 C# 版本的杀手锏是查询表达式,也就是语言集成查询 (LINQ)。LINQ 的构造可以建立在更细微的视图检查表达式树、Lambda 表达式以及匿名类型的基础上。...不过无论如何 C# 3.0 都提出了革命性的概念。 C# 3.0 开始为 C# 转变为面向对象/函数式混合语言打下基础。...09 LINQ 基础07 LINQ 中的查询语法和方法语法 C#3.0 新增功能09 LINQ 基础08 支持 LINQ 的 C# 功能 C#3.0 新增功能09 LINQ 标准查询运算符 01...迭代器 C#2.0 新增功能06 协变与逆变 C#2.0 新增功能07 getter/setter 单独可访问性 除现有功能以外的其他 C# 2.0 功能: 方法组转换(委托) 静态类 委托推断 C

    1.9K10

    C# Break 和 Continue 语句以及数组详解

    in arrayName) { // 要执行的代码块 } 以下示例使用 foreach 循环输出 cars 数组中的所有元素: 示例 string[] cars = {"Volvo", "BMW...命名空间 其他有用的数组方法,如 Min、Max 和 Sum,可以在 System.Linq 命名空间中找到: 示例 using System; using System.Linq; namespace...} } } C# Multidimensional Arrays 多维数组 如果您想将数据存储为表格形式,比如具有行和列的表格,您需要了解多维数组。...或者更好地说,考虑到表格的可视化;一个用于行,一个用于列(见下面的示例)。...以下示例将更改第一行(0)和第一列(0)中元素的值: 示例 int[,] numbers = { {1, 4, 2}, {3, 6, 8} }; numbers[0, 0] = 5; // 更改值为

    16710

    C#3.0新增功能09 LINQ 标准查询运算符 04 运算

    下节列出了执行限定符运算的标准查询运算符方法。 方法 方法名 说明 C# 查询表达式语法 详细信息 全部 确定是否序列中的所有元素都满足条件。 不适用。...这些方法执行同等联接,即根据 2 个数据源的键是否相等来匹配这 2 个数据源的联接。 (与此相较,Transact-SQL 支持除“等于”之外的联接运算符,例如“小于”运算符。)...(C#) 匿名类型 构建联接和叉积查询 join 子句 如何:使用组合键进行联接 如何:联接不同文件的内容 (LINQ) (C#) 如何:对 join 子句的结果进行排序 如何:执行自定义联接操作 如何...:执行分组联接 如何:执行内部联接 如何:执行左外部联接 如何:从多个源填充对象集合 (LINQ) (C#) 08 数据分组 分组是指将数据分到不同的组,使每组中的元素拥有公共的属性。...标准查询运算符概述 (C#) group 子句 如何:创建嵌套组 如何:按扩展名对文件进行分组 (LINQ) (C#) 如何:对查询结果进行分组 如何:对分组操作执行子查询 如何:使用组将一个文件拆分成多个文件

    9.7K20

    Linq调试实时输出信息扩展方法(摘抄)

    原文在此 [译]如何在C#中调试LINQ查询 原linq语句: var res = employees .Where(e => e.Gender == "Male") .Take(3) .Where(e...它可以选择打印通过此操作的所有项目和总数。 logName是每个输出的前缀,可以轻松查看编写它的查询步骤。我喜欢将其命名为之后操作相同的名称。...在上面的示例中,我选择使用 e=>e.Name打印员工的姓名,当为 null时,除总数外,不会打印任何内容。 为了优化,此方法尽在调试模式下有效( #if DEBUG)。...每个项目都按顺序打印,无需等待操作结束,这是因为LINQ的 lazy 特性。以下是查看单个操作结果的提示:将整个输出复制到 notepad++。...这将仅显示与日志名称前缀匹配的行。

    80520

    C#3.0新增功能09 LINQ 基础04 基本 LINQ 查询操作

    本篇介绍 LINQ 查询表达式和一些在查询中执行的典型操作。 获取数据源 在 LINQ 查询中,第一步是指定数据源。 和大多数编程语言相同,在使用 C# 时也必须先声明变量,然后才能使用它。...有关详细信息,请参阅如何:使用 LINQ 查询 ArrayList (C#) 和 from 子句。 筛选 或许,最常见的查询操作是以布尔表达式的形式应用筛选器。...例如,可通过执行联接来查找所有位置相同的客户和分销商。 在 LINQ 中,join 子句始终作用于对象集合,而非直接作用于数据库表。...选择(投影) select 子句生成查询结果并指定每个返回的元素的“形状”或类型。...当 select 子句生成除源元素副本以外的内容时,该操作称为投影 。 使用投影转换数据是 LINQ 查询表达式的一种强大功能。

    3.5K20

    如何给已经有数据的DataTable动态增加一列并赋值

    以前手写sql的时代,我们经常用DataTable,自从用Linq后,很少用DataTable这些原始的东东了,近日在开发中遇到一些特殊情况,用户要求临时在显示数据上增加一列(该列是根据业务逻辑动态计算得来的一个数字...),想了下,还是直接用DataTable来得方便(当然用List,自己构造T类型也能解决,不过考虑这些需求只是一些临时性的,单独为这些临时性的要求写一个自定义类未免太麻烦) 代码不复杂,贴在这里主要是为了留个备份...,以后忘了的时候,好方便查找: Code DataTable _tbl = new DataTable(); _tbl.Columns.Add("F_Name", Type.GetType...tbl.Rows.Add(new object[] { "bbb", 2 }); _tbl.Columns.Add("F_Time", Type.GetType("System.DateTime...tbl.Rows.Count; i++) { _tbl.Rows[i][_tbl.Columns.Count - 1] = DateTime.Parse

    3.2K90

    委托表示回调

    需转载请联系 494324190@qq.com 回调是一种由服务端提供一部反馈的机制,它在某些情况下会涉及到多线程或者为同步更新提供入口,在 C# 中如果要编写良好的回调那么就必须用委托来表示回调。...在这三种定义委托的形式中第一种形式可以用第二种形式来替代,也就是说 Predicate 是用来判断某条条件是否成立,而 Func 则会根据一些列参数求出某个结果,因此 Func 是等同于...Tip:我们常用的 LINQ 就是以委托为基础构建的,回调则用于处理 WPF 和 WinForm 中的跨线程封送。...在 C# 里需要注意的是所有的委托都是多播委托,也就是说会把添加到委托中的所有目标函数都视为一个整体去执行。...由于每个委托都是一列表的形式来保存其中的目标函数的,因此只要在这个列表上迭代把每个目标函数执行一遍。 总结 如果要在程序运行时执行回调,那么最好的办法是使用委托。

    87740
    领券