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

Excel公式练习64: 获取单元格区域中移除空单元格后的值

本次的练习是:如下图1所示,列C中有很多空单元格,使用公式将其整理,移除空单元格并将值放置在列D中。 ? 图1 先不看答案,自已动手试一试。...公式 在单元格D2中,输入数组公式: =IFERROR(OFFSET(C2,SMALL(IF((List)>1,ROW(List),""),ROW(E1))-2,0),"") 下拉至单元格出现空为止。...公式中的List为名称,引用列C中的单元格区域C2:C10000。...图4 这样,在单元格D2中的公式最终等价为: OFFSET(C2, 2-2,0) 得到单元格C2中的值。...在单元格D3中的公式最终等价为: OFFSET(C2, 6-2,0) 得到单元格C6中的值。 在单元格D4中的公式最终等价为: OFFSET(C2, 7-2,0) 得到单元格C7中的值。 依此类推。

3.1K51

Excel实战技巧111:自动更新的级联组合框

与传统的数据验证(即“数据有效性”)下拉列表相比,组合框表单控件具有许多优点。 下拉指示器在组合框中始终可见;而在数据验证中,用户必须单击单元格来显示下拉指示器。...在“设置控件格式”的“控制”选项卡(如下图4所示)中,有两个重要的属性: 数据源区域:包含要在下拉列表中显示的项目的单元格。 单元格链接:用于保存用户从列表中选择的单元格。...图5 从图5中可以看到,组合框的选择与单元格K4链接,当我们选择组合框中的下拉列表项时,将会在该单元格中放置所选项在列表中的位置值。 下面,我们来创建级联的组合框。...在刚才的组合框下面,插入第二个组合框,如下图6所示。 图6 要使用“App内容”填充第二个组合框,可以使用多种方法: 直接引用包含项目的单元格。 使用公式创建动态列表。...注意到,当我们选择不同部门时,由于其对应的App列表长度不同,列表底部会存在空,如下图12所示。 图12 在此,我们通过定义名称来解决。

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

    VBA技巧:当单元格区域中包含由公式返回的空单元格时,如何判断?

    标签:VBA 在VBA中,我们经常会遇到需要检查某个单元格区域是否为空的情形。我们可以使用下面程序中的代码来检查单元格区域是否为空。...Sub CheckIfBlank() If WorksheetFunction.CountA(Range("A1:A100")) Then MsgBox "单元格区域不全为空单元格..." Else MsgBox "单元格区域为空" End If End Sub 然而,如果单元格区域偶然包含一个返回为空的公式,则上述代码不会将该单元格区域返回为空,因为它包含公式返回为空的单元格...要处理这个问题,可以使用下面的命令来检查单元格区域是否为空,即使该单元格区域包含返回空的公式。..." Else MsgBox "单元格不全为空单元格" End If End Sub 这将同时适用于任意连续的单元格区域。

    2.3K10

    精通Excel数组公式14:使用INDEX函数和OFFSET函数创建动态单元格区域

    动态单元格区域是指当添加或删除源数据时,或者随着包含单元格区域的公式被向下复制时根据某条件更改,可以自动扩展或收缩的单元格区域,可以用于公式、图表、数据透视表和其他位置。...如果要获取整列,那么只需要给INDEX函数指定代表列号的参数column_num的值,忽略参数row_num(为空)或者指定其值为0。...图2:对于不同数据类型查找最后一行 在图2所示的公式[2]至[6]中,展示了一种近似查找值的技术:当要查找的值比单元格区域中的任何值都大且执行近似匹配(即MATCH函数的第3个参数为空)时,将总是获取列表中最后一个相对位置...图4:当有6条记录时查找单元格区域中的最后一项 使用INDEX和MATCH函数创建可以扩展和缩小的动态单元格区域 如下图5所示,在单元格E2中是一个数据有效性下拉列表,其内容来源于单元格区域A2:A5,...图5:下拉列表和VLOOKUP公式 问题是,当在单元格区域A2:C5的下方添加更多的数据时,数据有效性下拉列表和VLOOKUP公式中的相应单元格区域都不会更新。

    9.3K11

    精通Excel数组公式021:提取唯一值列表并排序

    下图1展示用于从单元格区域B2:B9中提取唯一的赛道名的公式。 ? 图1 数组公式:从单列中提取唯一值列表,使用SMALL函数 下图2展示了使用数组公式统计唯一值数量。...图4 如果将上图4中的空单元格填充值,则结果会自动更新。 数组公式:使用动态单元格区域并从单列中提取唯一值列表 如下图5所示,在公式中使用了定义的名称来统计唯一值的个数。 ?...注意到,在统计唯一值个数的公式中,使用了ISTEXT函数,这样可以将数字、非文本的单元格排除。 下图6展示了提取唯一值列表的公式,忽略了区域中的数字单元格。 ?...图6 创建唯一值列表作为数据有效性下拉列表项 继续使用前一个示例,将得到的唯一值列表作为数据有效性下拉列表项。...注意,SUMIF函数的参数sum_range指定值为单个单元格,此时该函数基于其用于在range参数中添加的客户区域的高度的单元格数。 ? 图11 将单元格E15和F15中的公式分别向下复制。

    5.2K10

    Excel公式技巧90:剔除单元格区域中的空单元格

    有时候,在一列数据中有许多空单元格,导致数据不连续,我们需要剔除这些空单元格,让数据区域连起来。 如下图1所示,在单元格区域A1:A15中输入了一些数据,但其间有许多空白单元格。 ?...图1 在单元格D1中,输入数组公式: =IFERROR(INDIRECT("A" & SMALL(IF(LEN(A15)=0,"",ROW(1:15)),ROW(A1))),"") 然后,向下复制直至出现空白单元格为止...公式的核心部分是: SMALL(IF(LEN(A1:A15)=0,"",ROW(1:15)),ROW(A1)) 首先,获取单元格区域A1:A15中每个单元格内数据的长度:LEN(A1:A15),看其是否为...0:LEN(A1:A15)=0,如果为0,则表明该单元格为空,返回一个空值,否则返回该单元格所在的行号:IF(LEN(A1:A15)=0,"",ROW(1:15)),对于本例来说,返回数组:{1;””;...接着,对于第一个公式来说,ROW(A1)返回1,即获取该数组中最小的值,即1。 然后,使用INDIRECT函数获取第1个非空单元格的值: INDIRECT(“A” & 1) 即单元格A1中的值。

    4.6K20

    Excel公式技巧100:遍历单元格中的数据

    有时候,我们需要从单元格数据中提取出满足条件的值。例如,下图1所示的单元格B3中的数据“NO13859724621”,我们想要得到相邻两个数字组成的最大的两位数。 ?...然而,怎么样使用公式获得这个值呢? 这就涉及到需要找到一种方法,从数据的开头开始,两个两个地取值,从而遍历整个数据,然后比较这些值,获取其中最大的值。...图2 公式中: MID(B3,ROW(A1:A100),2) 从单元格B3中的第一个字符开始,按顺序依次获得两个字符组成的数值,如下图3所示。 ?...图3 传递到VALUE函数中,将代表数值的文本字符串转换为数值,如下图4所示。 ? 图4 IFERROR函数将错误值#VALUE!转换成空,如下图5所示。 ?...2.上述公式中,使用了ROW(A1:A100),假设单元格数据长度为100,其实可以使用下面的数组公式: =MAX(IFERROR(VALUE(MID(B3,ROW(INDIRECT("1:"& LEN

    6.5K20

    Excel公式练习33: 将包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格(续)

    本次的练习是:这个练习题与本系列上篇文章的练习题相同,如下图1所示,不同的是,上篇文章中将单元格区域A1:D6中的数据(其中包含空单元格)转换到单独的列(如图中所示的单元格区域G1:G13)中时,是以行的方式进行的...这里,需要以列的方式进行,即先放置第1列中的数据、再放置第2列中的数据……依此类推,最终结果如图中所示的单元格区域H1:H13,如何使用公式实现? ? 图1 先不看答案,自已动手试一试。...公式 1.先将单元格区域A1:D6命名为“rngData”。 2.在单元格F1中输入公式: =SUM(COUNTIF(rngData,{">0","?...*"})) 统计单元格区域A1:D6中非空单元格的数量。并将该单元格作为辅助单元格。...相关参考 Excel公式练习32:将包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格 Excel公式练习4:将矩形数据区域转换成一行或者一列

    2.4K10

    Excel公式练习32: 将包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格

    本次的练习是:如下图1所示,单元格区域A1:D6中是一系列数据,其中包含空单元格,现在要将它们放置到一列中,并删除空单元格,如图中所示的单元格区域G1:G13,如何使用公式实现? ?...*"})) 统计单元格区域A1:D6中非空单元格的数量。并将该单元格作为辅助单元格。...因此,如果结果大于单元格F1中的值,则公式结果为空,否则执行IF语句的第2部分。...直接在单元格G1中输入,然后下拉至得到的结果为空为止。...这个公式的缺点是,当下拉很多行时,如果有许多行都为空,则仍会进行很多的计算,占有资源,不会像前面给出的公式,第一个IF判断为大于非空单元格值后,直接输入空值。有兴趣的朋友可以仔细研究。

    2.4K10

    Excel公式练习:合并单元格中的条件求和

    引言:本文的练习整理自chandoo.org。多一些练习,想想自己会怎么解决这个问题,看看别人又是怎样解决的,这样能够快速提高Excel公式编写水平。 本次的练习是:示例数据如下图1所示。...图1 现在,想根据列A中的数据对列B中的值汇总。例如,对于列A中的“A”来说,在列B中对应的值是:1、13、14、15、16、17、18,其和为94。...我们将单元格区域A2:A21命名为“D”,单元格区域B2:B21命名为“V”。 要求只能使用公式,不能使用VBA,仅能使用上述两个命名区域名称,不能使用填充功能填充空单元格。 请写下你的公式。...解决方案 公式1:数组公式。...…… 公式并没有给出详细的解析,有兴趣的朋友可以参照前面推送的有关分析公式的文章对这些公式进行解析,相信对理解Excel函数,编写公式解决问题会有很大的帮助。

    2.5K30

    Excel技巧:锁定包含公式的单元格

    标签:Excel技巧,保护工作表 有时候,我们想保护工作表中的公式,不让用户能够随便修改,但是又不想限制用户编辑除公式之外的数据。...步骤2:单击鼠标右键,从快捷菜单中选择“设置单元格格式”命令。在弹出的“设置单元格格式”对话框中选择“保护”选项卡,取消“锁定”前复选框中的勾选,如下图1所示。...步骤4:单击“定位条件”对话框中的“公式”单选按钮,如下图3所示,单击“确定”。 图3 此时,Excel选择工作表中所有包含公式的单元格。...步骤5:单击鼠标右键,从快捷菜单中选择“设置单元格格式”命令。在弹出的“设置单元格格式”对话框中选择“保护”选项卡,选取“锁定”前的复选框,如下图4所示。...图4 步骤6:单击功能区“审阅”选项卡中的“保护工作表”命令。 此时,如果想修改工作表中包含公式的单元格,则会弹出如下图5所示的警告框。

    3.1K20

    Word VBA技术:判断表格中的单元格是否为空

    标签:Word VBA 可以使用VBA代码来判断文档中表格内的单元格是否为空。下面的代码检查所选文档内容中表格内的单元格,并给出空单元格的信息。...方法1 基于空单元格由Chr(7)跟随的段落标记组成,可以使用Range对象检测空单元格,代码如下: Sub CheckTableCells() Dim rngCell As Cell...End If Next rngCell Next rngRow End Sub 方法2 使用Range变量,将其设置为标记每个单元格的区域,移动到区域的末端,使单元格末端标记和段落标记不包含在区域中...如果单元格为空,则区域内没有文本。...End If Next rngCell Next rngRow End Sub 方法3 下面的代码与方法1类似,只是在给出空单元格信息之前先选择该单元格。

    3.7K60

    如何在HTML的下拉列表中包含选项?

    为了在HTML中创建下拉列表,我们使用命令,它通常用于收集用户输入的表单。为了在提交后引用表单数据,我们使用 name 属性。如果没有 name 属性,则下拉列表中将没有数据。...用于将下拉列表与标签相关联;id 属性是必需的。要在下拉列表中定义选项,我们必须在 元素中使用 标签。...价值发短信指定要发送到服务器的选项的值倍数倍数通过使用,可以一次选择多个属性选项。名字名字它用于在下拉列表中定义名称必填必填通过使用此属性,用户在提交表单之前选择一个值。...大小数此属性用于定义下拉列表中可见选项的数量价值发短信指定要发送到服务器的选项的值自动对焦自动对焦它用于在页面加载时自动获取下拉列表的焦点例以下示例在HTML的下拉列表中添加一个选项 标签和 标签在列表中添加选项 -<!

    38320

    Excel 2013中单元格添加下拉列表的方法

    使用Excel录入数据的时候我们通常使用下拉列表来限定输入的数据,这样录入数据就很少发生错误了。Excel 2013较以前的版本发生了很大的变化,那么在Excel 2013是如何添加下拉列表的呢?...下面Office办公助手的小编就以“性别”中下拉选择男女为例,讲解下Excel 2013中添加下拉列表的方法。更复杂的大家可以举一反三,方法是一样的。 1、首先要选中你要添加下拉列表的单元格。...3、打开如图所示的对话框,切换到设置选项下。 4、将允许条件设置为序列,如图所示,并勾选后面的两个选项。 5、接着设置来源为男女,记得两个字之间有一个逗号。...6、到这里,这个单元格已经设置完毕,我们可以使用快速填充来对整列进行填充。 7、拖动单元格的右下角,向下拖动即可完成快速填充。 8、我们看到这列单元格都具有了下拉列表。

    2.7K80

    精通Excel数组公式15:使用INDEX函数和OFFSET函数创建动态单元格区域(续)

    将动态单元格区域公式定义为名称 创建动态单元格区域的公式不能直接用于创建数据有效性下拉列表。然而,可以将其定义为名称,然后在创建数据有效性下拉列表时使用这个名称。...2.如果对包含需要按Ctrl+Shift+Enter的公式创建定义名称,然后在单元格公式中使用该定义名称,那么不需要按Ctrl+Shift+Enter。...公式中,动态单元格区域的起始位置为单元格A2,没有向下和向右偏移(参数rows和cols均为空),高度(参数height)为2,宽度(参数width)为1(公式中省略了该参数,取默认值)。...接着,在公式栏中,将代表的数据区域修改为上面定义的名称。 示例:总是获取一列中倒数5个数字 如下图10所示,在单元格区域A2:A10中包含一些数字和空单元格。现在,想要使用公式求倒数5个数据之和。...图10:计算一列中倒数5个数字之和 很显然,最后一个数据是单元格A8中的1,倒数5个数据,如果包含空单元格,则为A4:A8;如果不包含空单元格,则为A3:A8。

    4.2K20

    Excel公式技巧98:总计单元格文本中的数字

    图1 单元格区域A2:B19中是记录每月一些物品的领用数据,但是数值和物品名称输入到了一起,现在需要分别统计每种物品领用数量的总和。...在单元格D3中输入数组公式: =SUM(IF(SUBSTITUTE(B2:B19,D2,"")B2:B19,SUBSTITUTE(B2:B19,D2,"")+0))& " " & D2 在单元格E3...中输入数组公式: =SUM(IF(SUBSTITUTE(B2:B19,E2,"")B2:B19,SUBSTITUTE(B2:B19,E2,"")+0))& " " & E2 在单元格F3中输入数组公式...在公式中,我们人为地将数据中的物品名称替换为空,然后与原数据进行对比,那么那些不相等的数据自然就是替换的物品的领用数值。...对于SUBSTITUTE(B2:B19,D2,"")+0中的+0,是为了将替换后的文本转换为数字,否则将得不到正确的结果。

    1.3K40

    【Excel】用公式提取Excel单元格中的汉字

    昨天一个前端的朋友找我帮忙用excel提取代码中的汉字(字符串),可算费了劲儿了,他要提取的内容均在单引号中,但问题是没有统一的规律,同一个单元格可能存在多个要提取的内容,而且汉字中间也夹杂其他字符。...所以总结了一下提取汉字的几种情况。 一、用公式提取Excel单元格中的汉字 对于一个混杂各种字母、数字及其他字符和汉字的文本字符串,要提取其中的汉字,在Excel中通常可用下面的公式。...如果字符串中的汉字之间有其它字符分隔,例如上图中的A14单元格,要提取其中的所有汉字,可用下面的自定义函数。方法是: 1....CreateObject("VBScript.RegExp") With regEx '搜索整个字符串 .Global = True '匹配非汉字 .Pattern = "[^\u4e00-\u9fa5]" '将字符串中的非汉字替换为空...返回Excel工作表界面,在B14单元格中输入公式: =提取汉字(A14) 即可取得A14单元格字符串中的所有汉字。 二、用公式提取引号(某2个相同字符)之间的内容 ?

    8.6K61

    Excel公式练习84:提取单元格中的10位数字

    今天的练习是:如下图1所示的数据,每个单元格中包含由换行符分隔的3个数字,现在需要提取其中10位长的数字,如图1中的B列所示。 ? 图1 先不看下面的答案,自已试试。...解决方案 公式1 可以试试下面的公式: =LOOKUP(9E+307,--MID(A2,ROW(INDIRECT("1:"& LEN(A2)-9)),10)) 该公式使用MID函数从单元格中的第1个数字开始依次取...10位数,共14个数字,这14个数字中,由于有空格的存在,所以除单元格中的10位数外,其余都是9位数。...然后使用LOOKUP函数在这些数字中进行查找,返回最大的一个数字,即单元格中的10位数。 公式2 试试下面的公式: =MID(A2,SEARCH(CHAR(10)&REPT("?"...,10)&CHAR(10),CHAR(10)&A2&CHAR(10)),10) 在单元格中搜索前后都是空格且中间是10位数的数字。

    2.3K30
    领券