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

Excel公式技巧20: 列表返回满足多个条件数据

在实际工作,我们经常需要从某列返回数据,该数据对应于另一列满足一个或多个条件数据最大值。 如下图1所示,需要返回指定序号(列A)最新版本(列B)对应日期(列C)。 ?...原因是与条件对应最大值不是在B2:B10,而是针对不同序号。而且,如果该情况发生在希望返回值之前行,则MATCH函数显然不会返回我们想要值。...B10,0)) 转换为: =INDEX(C2:C10,MATCH(4,B2:B10,0)) 转换为: =INDEX(C2:C10,MATCH(4,{4;2;5;3;1;3;4;1;2},0)) 很显示,数组第一个满足条件值并不是我们想要查找值所在位置...: =INDEX(C2:C10,1) 得到: 2013-2-21 这并不是满足我们条件对应值。...由于数组最小值为0.2,在数组第7个位置,因此上述公式构造结果为: {0;0;0;0;0;0;1;0;0;0} 获得此数组后,我们只需要从列C与该数组出现非零条目(即1)相对应位置返回数据即可

8.5K10

Excel公式练习45: 矩阵数组返回满足条件所有组合数

本次练习是:如下图1所示,在一个4行4列单元格区域A1:D4,每个单元格内都是一个一位整数,并且目标值单元格(此处为F2)也为整数,要求在单元格G2编写一个公式返回单元格A1:D4四个不同值组合数量...,条件如下: 1....这四个值总和等于F2值 2. 这四个值彼此位于不同行和列 ? 图1 下图2是图1示例满足条件6种组合。 ? 图2 先不看答案,自已动手试一试。...关键是,参数cols固定为数组{0,1,2,3},显然意味着四个元素组合每个都将分别来自四个不同列,然后变换传递给参数rows数组,即满足确保没有两个元素在同一行条件所有可能排列。...虽然我们可以将诸如SMALL之类函数与其他一些函数例如LARGE、FREQUENCY或MODE.MULT一起使用,返回一个大小与传递给函数大小不同数组,但是通常根本没有必要将数组缩减到这样程度:

3.2K10
您找到你想要的搜索结果了吗?
是的
没有找到

Excel公式练习87:返回字符串第一数字之后所有内容

本次练习是:如下图1所示,使用公式拆分列A字符串,从中返回列B字符串。...例如,如果字符串是Monaco7190Australia1484,那么返回第一数字右侧所有字符串Australia1484。...图1 你公式应该处理任意长度字符串和任意长度数字——不仅仅是图1所显示长度。此外,不应该使用任何辅助单元格、中间公式或命名区域,或者VBA。 如何使用公式获得结果?...问题难点在于有一个文本,然后是一个数字块,接着是我们实际想要提取文本/数字块。因此,由于前面有一个文本/数字块,很难确定第二个文本/数字块位置。...0;1;0;0;0;0;0;0;0;0;0;0;0;0;1},0) 返回: 10 7.接着返回该位置右侧原始字符串所有字符 =MID(A2,1+10,LEN(A2)) 返回: Australia1484

2.5K30

Excel公式练习88:返回字符串第一数字之后所有内容(续1)

引言:在《Excel公式练习87:返回字符串第一数字之后所有内容,我们给出了解决这个问题一个公式,本文中,尝试着使用另一个公式来解决这个问题。...本次练习是:如下图1所示,使用公式拆分列A字符串,从中返回列B字符串。...例如,如果字符串是Monaco7190Australia1484,那么返回第一数字右侧所有字符串Australia1484。...图1 你公式应该处理任意长度字符串和任意长度数字——不仅仅是图1所显示长度。此外,不应该使用任何辅助单元格、中间公式或命名区域,或者VBA。 如何使用公式获得结果?...图4 终于搞清楚了,第一个数组与第二个数组唯一一个相同数字交界地方就是第一个数字块结束和第二个字母开始地方。

1.3K20

Excel公式练习90:返回字符串第一数字之后所有内容(续3)

引言:在《Excel公式练习87:返回字符串第一数字之后所有内容》、《Excel公式练习88:返回字符串第一数字之后所有内容(续1)》和《Excel公式练习89:返回字符串第一数字之后所有内容...正如之前已提到过,尝试多种方法解决问题,能够帮助我们快速提高。 本次练习是:如下图1所示,使用公式拆分列A字符串,从中返回列B字符串。...例如,如果字符串是Monaco7190Australia1484,那么返回第一数字右侧所有字符串Australia1484。...图1 你公式应该处理任意长度字符串和任意长度数字——不仅仅是图1所显示长度。此外,不应该使用任何辅助单元格、中间公式或命名区域,或者VBA。 如何使用公式获得结果?...因此,如果计算出0 和-1组合落在哪里,我们就确切地知道我们想要子串哪里开始。

1.3K10

Excel公式练习89:返回字符串第一数字之后所有内容(续2)

引言:在《Excel公式练习87:返回字符串第一数字之后所有内容》和《Excel公式练习88:返回字符串第一数字之后所有内容(续1)》,我们分别给出了解决这个问题两个公式,本文中,再次尝试着使用另一个公式来解决这个问题...正如之前已提到过,尝试多种方法解决问题,能够帮助我们快速提高。 本次练习是:如下图1所示,使用公式拆分列A字符串,从中返回列B字符串。...图1 你公式应该处理任意长度字符串和任意长度数字——不仅仅是图1所显示长度。此外,不应该使用任何辅助单元格、中间公式或命名区域,或者VBA。 如何使用公式获得结果?...";7;22;9}) 返回: 8 因此,已经计算出第一组数字开始位置是第8个字符,这意味着可以完全忽略出现在这个位置之前任何文本。...4.获取第二开始 现在,可以位置8搜索下一个字母。那个字母将是我们所求文本开始。

2K20

就是个控制结构,Scala能有什么新花样呢?

形式虽然一样,但Scala其实也有其特别之处:那就是Scalaif-else其实应当理解成一个代码,而在Scala但凡是代码,基本上都对应有返回值,所以无论是单分支、双分支还是多分支,其返回值就是相应分支结果...同时需指出是,在单分支只有if单条语句,当条件不满足时实际上也是对应控制返回结果。...正因为if-else都是有返回,所以Scala并未设立像其他语言中那样三元选择运算符,而是交由if-else完成这一功能。...仍属于一个代码,也是有返回。...) 1 2 4 3 6 9 for循环在Scala仍然属于一个代码,所以其实也是有返回

84620

Scala基础语法

//如果缺失else,相当于if (x > 2) 1 else ()     val m = if (x > 2) 1     println(m) //在scala每个表达式都有值,scala中有个... (x < 0) 0 else if (x >= 1) 1 else -1     println(k)   } } Scala表达式 package com.itunic.scala /**...{}课包含一系列表达式,中最后一个表达式值就是值 //下面就是一个表达式     val result = { if (x < 0) {         -1       } else...+(b) a 方法 b可以写成 a.方法(b) Scala定义方法及函数 定义方法 方法返回值类型可以不写,编译器可以自动推断出来,但是对于递归函数,必须指定返回类型。...定义函数 Scala方法与函数区别 在函数式编程语言中,函数是“头等公民”,它可以像任何其他数据类型一样被传递和操作 案例:首先定义一个方法,再定义一个函数,然后将函数传递到方法里面。

61630

Scala编程基础01

一样,有7种数值类型Byte、Char、Short、Int、Long、Float和Double(无包装类型)和一个Boolean类型 3.条件表达式 Scala条件表达式比较简洁,例如:     val...()     val m = if (x > 2) 1     println(m)     //在scala每个表达式都有值,scala中有个Unit类,写做(),相当于Javavoid    ...>= 1) 1 else -1     println(k) 4.表达式 val x = 0     //在scala{}课包含一系列表达式,中最后一个表达式值就是值     //下面就是一个表达式...//每次迭代生成集合一个值     val v = for (i <- 1 to 10) yield i * 10     println(v) 6.调用方法和函数 Scala+ - * / %...在函数式编程语言中,函数是“头等公民”,它可以像任何其他数据类型一样被传递和操作  //定义一个方法   //方法m2参数要求是一个函数,函数参数必须是两个Int类型   //返回值类型也是Int类型

12310

Scala第四章节

顺序结构 2.1 概述 顺序结构是指: 程序是按照从上至下, 左至右顺序, 依次逐行执行, 中间没有任何判断和跳转....在scala条件表达式也是有返回scala,没有三元表达式,可以使用if表达式替代三元表达式 示例 定义一个变量sex,再定义一个result变量,如果sex等于"male",result...打印max值 println("max: " + max) 注意: 嵌套一般不超过3层. 3.8 扩展: 表达式 scala,使用{}表示一个表达式 和if表达式一样,表达式也是有值...**参考代码: ** //定义一个变量, 记录1到10数字 val nums = 1 to 10 //to是Scala一个关键字 //通过for循环, 打印指定内容 for(i <- nums)...i <- 1 to 10 if i % 3 == 0) println(i) 4.4.5 for推导式 Scalafor循环也是有返回, 在for循环体,可以使用yield表达式构建出一个集合

49820

学好Spark必须要掌握Scala技术点

= 0 // scala{}可包含一系列表达式,运行最终结果为值 val result = { if(x =...在Scala,有两种Map: 不可变Map:scala.collection.immutable.Map(可以存储一些配置或参数供多个线程访问,保证线程安全,具体还要结合业务实际场景),内容不可更改...可变Map:scala.collection.mutable.Map==>类似于JavaHashMap,可以进行put、get、remove等操作,内容可变 ?...模式匹配和样例类 4.1 模式匹配 Scala有一个十分强大模式匹配机制,可以应用到很多场合:替代Javaswitch语句、类型检查等。...case _ => println("else") }*/ /* val lst = List(0,-1,1,2) //head首元素,tail除首元素之外元素 take1开始取

1.5K50

大数据--scala学习第一章:基础第二章:控制结构和函数第三章:数组第四章:字典和元组第五章:类第六章:对象第七章:包和引入第八章:继承第九章文件和正则表达式第十章特质:接口第十一章操作符第十二章函

第二章:控制结构和函数 1、条件表达式:if(x>0) 1 else -1 或 if(x>0){ 1 }else{ -1}。此处1 else -1 是一个表达式,返回类型是两个分支公共类型。...2、Unit就是Javavoid,可以用()代替。 3、表达式:{}表示为,也是表达式,其返回类型是中最后一个表达式值。...2、Scala作用域更加前后一致,子包可以直接使用父包内容。 3、Scala引入了包对象,包对象可以定义方法,属性。...5、引入类似于Java引入,引入全部写法是 _不是*:import java.awt._ 。更加灵活是可以在任何地方都可以声明引入。...该类有两个方法,apply方法用于模式匹配,一个isDefinedAt输入匹配到则返回True。

4.4K20

scala(三) 流程控制

分支控制if-else Scala IF...ELSE 语句是通过一条或多条语句执行结果(True或者False)来决定执行代码。...if...else 语法: if (条件表达式1) { 执行代码1 } else if(条件表达式1){ 执行代码2 } else if(条件表达式2){ 执行代码...嵌套分支 在一个分支结构又完整嵌套了另一个完整分支结构,里面的分支结构称为内层。...scala:就这?我强大你还没发掘呢。 我:? 表达式 定义:由{}包裹一段代码称为快表达式,表达式可以有返回值,返回值是{}中最后一个表达式结果值。...在 Scala 中一切皆为对象,if-else 也一样,是对象就有返回,if-else 返回值 就是程序语句最后一个代码结果。

16720

Scala 学习笔记之基础语法

变量 val定义值实际上是一个常亮,无法改变其内容 scala> val num = 0 num: Int = 0 scala> num = 2 :12: error: reassignment...> number = 2 number: Int = 2 在Scala,建议使用val,除非你真的需要改变它内容....条件表达式 Scala if/else 语法结构和Java一样.不过,在Scala if/else 表达式有值,这个值就是跟在 if 或 else 之后表达式值: if(x > 0) 1...备注 Scala每个表达式都有一个类型 scala> val s = if(x > 0) "positive" else -1; s: Any = positive 上述表达式类型是两个分支类型公共超类型...如果函数体需要多个表达式完成,可以使用代码中最后一个表达式值就是函数返回值: def fac(n: Int) = { var r = 1 for(i <- 1 to n){

53310

Scala学习一

一、scala方法 1.Scala中方法格式 def 方法名(参数名:参数类型,参数名:参数类型):[return type]={//方法体} 省略条件: 1.参数列表参数类型不能省略 2.参数值类型可以省略...,由scala编译器自动推断 3.返回值可以不写return,默认就是{}表达式值 4.定义递归方法,不能省略返回值类型 :获取最大值 //定义方法 def getMaxNum(a:Int, b:...: " + maxNum) 根据上面的省略条件2可以进行省略: //定义方法 def getMaxNum(a:Int, b:Int) = if(a>b) a else b //调用方法 val maxNum...类似java延迟加载。同时lazy不能修饰var类型变量。...方法与函数: 方法是属于类或者对象,在运行时,它是加载到JVM方法区,而函数则是加载到JVM堆内存,同时可以将函数对象赋值给一个变量。

39021

大数据技术之_16_Scala学习_03_运算符+程序流程控制

2、Scala 任意表达式都是有返回,也就意味着 if else 表达式其实是有返回结果,具体返回结果值取决于执行满足条件代码体最后一行内容。...示例代码如下:     // Scala 任意表达式都是有返回,也就意味着 if else 表达式其实是有返回结果,具体返回结果值取决于执行满足条件代码体最后一行内容。     ...1 : 0     // Scala     val result = if (flag) 1 else 0   // 因为 scala  if-else 是有返回,因此,本身这个语言也不需要三元运算符了...5、Scala 任意表达式都是有返回,也就意味着 if else 表达式其实是有返回结果,具体返回结果值取决于执行满足条件代码体最后一行内容。...,也没有返回函数,即可以简单地理解可以接收一段代码

1.2K10

2021年大数据常用语言Scala(七):基础语法学习 条件表达式

条件表达式 条件表达式就是if表达式,if表达式可以根据给定条件是否满足,根据条件结果(真或假)决定执行对应操作。scala条件表达式语法和Java一样。...有返回if 与Java不一样是, [!...NOTE] 在scala条件表达式也是有返回scala,没有三元表达式,可以使用if表达式替代三元表达式 示例 定义一个变量sex,再定义一个result变量,如果sex等于"male",...result等于1,否则result等于0 参考代码 scala> val sex = "male" sex: String = male scala> val result = if(sex == ..."male") 1 else 0 result: Int = 1 表达式 scala,使用{}表示一个表达式 和if表达式一样,表达式也是有值 值就是最后一个表达式值 问题 请问以下代码,变量

27430

Scala学习教程笔记一之基础语法,条件控制,循环控制,函数,数组,集合

比如"hello world"(6)可以写成"hello world".apply(6); 2:Scala条件控制学习笔记: 1:if表达式定义:在scala,if表达式是有值,就是if或者else...3:如果if后面没有跟else,则默认else值是Unit,也可以用()表示,类似于Javavoid或者null。...指就是{}值,其中可以包含多条语句,最后一个语句值就是表达式返回值。...2:for循环,比如:for(i <- 1 to 10) println(i);注意for循环使用,多加揣摩和练习。 3:跳出循环语句:scala没有提供Java跳出循环语句。...,面向对象和面向函数编程: 1:函数定义:需要定义函数函数名,参数,函数体;Scala要求必须给出所有参数类型,但是不一定给出函数返回类型,只要右侧函数体不包含递归语句,Scala就可以根据自己右侧表达式推断出返回类型

1.4K50
领券