ad

excel公式教程: 求一列中的数字剔除掉另外一列中的数字后剩下的数字-英雄云拓展知识分享

匿名投稿 19325 2024-09-30

excel公式教程:以下图1所示,在单元格区域A2:A12和B2:B12中给定两列数字,要在列C中从单元格C2开始生成一列数字。规则以下:

1. 列B中的数字的数量要小于等于列A中数字的数量。

2. 列B中的任意数字都可以在列A中找到。

3. 在列A或列B已寄存数字的单元格之间不能有任何空单元格。

4. 在列C中的数字是从列A中的数字移除列B中的数字在列A中第一次出现的数字后剩下的数字。

5. 换句话说,列B和列C中的数字合起来就是列A中的数字。

excel公式教程: 求一列中的数字剔除掉另外一列中的数字后剩下的数字-英雄云拓展知识分享

图1

在单元格D1中的数字等于列A中的数字数量减去列B中的数字数量后的值,也就是列C中数字的数量。

现在,要在单元格C2中编写一个公式,然后下拉至单元格C12,得到如上图1所示的结果。

那末,如何编写这个公式呢?

先不看答案,自已动手试一试。

公式

在单元格C2中输入数组公式:

=IF(ROWS($1:1)>$D$1,””,SMALL(IF(1-ISNUMBER(MATCH(List1+(COUNTIF(OFFSET(INDEX(List1,1,1),Arry1,,Arry2,),List1)/10^6),List2+(COUNTIF(OFFSET(INDEX(List2,1,1),Arry1,,Arry2,),List2)/10^6),0)),List1),ROWS($1:1)))

向下拖拉至单元格C12。

公式解析

这个案例中,存在的最大障碍是列表中的值有重复,如果能够消除这个障碍,那末就好办了。公式的思路就是构造一个数组,能够实现在List1和List2之间履行MATCH函数查找时,列C中的数值就是找不到的值,返回FALSE。

但是,实现起来其实不是想像中的那末简单。我们必须首先确保生成的值是唯一的,并且依然可以经过某种方式与原始值相对应,从而提取出原始值。

公式中的List1、List2、Arry1和Arry2是定义内涵的4个名称。

名称:List1

援用位置:=$A$2:$A$12

名称:List2

援用位置:=$B$2:$B$12

名称:Arry1

援用位置:=ROW(List1)-MIN(ROW(List1))

名称:Arry2

援用位置:=ROWS(List1)-ROW(List1)+MIN(Row(List1))

在单元格D1中,使用下面的公式肯定列C中要返回的数字数量:

=COUNT(List1)-COUNT(List2)

1. 在公式中IF子句的第一部份:

IF(ROWS($1:1)>$D$1,””

非常直观,如果公式向下拖放后ROWS函数的值大于7,则返回空。

重点在IF子句的第2部份,即其判断条件为FALSE的部份。

2. 看看公式中的COUNTIF函数部份:

COUNTIF(OFFSET(INDEX(List1,1,1),Arry1,,Arry2,),List1)

其中:

(1)INDEX(List1,1,1)

返回对List1中的第1个单元格的援用,示例中为单元格A2。

(2)OFFSET函数中的参数rows和height分别是Arry1和Arry2。现在看看这两个名称。

对Arry1:

=ROW(List1)-MIN(ROW(List1))

转换为:

{2;3;4;5;6;7;8;9;10;11;12}-MIN({2;3;4;5;6;7;8;9;10;11;12})

转换为:

{2;3;4;5;6;7;8;9;10;11;12}⑵

得到:

{0;1;2;3;4;5;6;7;8;9;10}

对Arry2:

=ROWS(List1)-ROW(List1)+MIN(Row(List1))

转换为:

11-{2;3;4;5;6;7;8;9;10;11;12}+MIN({2;3;4;5;6;7;8;9;10;11;12})

转换为:

11-{2;3;4;5;6;7;8;9;10;11;12}+2

得到:

{11;10;9;8;7;6;5;4;3;2;1}

(3)现在,上述COUNTIF函数部份变成:

COUNTIF(OFFSET(A2,{0;1;2;3;4;5;6;7;8;9;10},,{11;10;9;8;7;6;5;4;3;2;1},),List1)

可以看到,传递了两个含有11个值的数组分别作为OFFSET函数的rows参数和height参数,这意味着我们给COUNTIF函数传递了11个单独的单元格区域。

第一个区域经过单元格A2偏移0行动出发点、高度为11行组成,即为单元格A2:A12;第2个区域经过单元格A2偏移1行动出发点、高度为10行组成,即为单元格A3:A12;第3个区域为A4:A12;第4个区域为A5:A12;依此类推,第11个区域为单元格A12。

对应于这11个单元格区域中的每一个区域,传递给COUNTIF函数的第2个参数criteria是Arry1中11个数组元素相应位置的值,因此,这种情况下,上述COUNTIF函数部份实际上履行以下公式运算:

=COUNTIF(A2:A12,A2)

=COUNTIF(A3:A12,A3)

=COUNTIF(A4:A12,A4)

=COUNTIF(A12:A12,A12)

得到数组:

{2;1;1;3;2;1;2;1;1;2;1}

这里,我们已成功生成一系列数值,可帮助我们来辨别List1中相同的数字。

3. 此时,公式中的部份:

List1+(COUNTIF(OFFSET(INDEX(List1,1,1),Arry1,,Arry2,),List1)/10^6)

转换为:

List1+({2;1;1;3;2;1;2;1;1;2;1}/10^6)

转换为:

List1+({0.000002;0.000001;0.000001;0.000003;0.000002;0.000001;0.000002;0.000001;0.000001;0.000002;0.000001})

转换为:

{1;1;2;3;3;3;4;4;5;6;6}+({0.000002;0.000001;0.000001;0.000003;0.000002;0.000001;0.000002;0.000001;0.000001;0.000002;0.000001})

结果为:

{1.000002;1.000001;2.000001;3.000003;3.000002;3.000001;4.000002;4.000001;5.000001;6.000002;6.000001}

虽然只是将List1中的各个数字增加了非常小的数字,但构成的数组中的每一个元素都是唯一的。举例来看,在原来的List1中有3个3,现在变成了3.000001、3.000002和3.000003。

注意,这里辨别这些List1中数字的小增量不只是随机的,相反,所不同的是,它们将计数每一个元素的数量。举例来看,如果在生成的数组中整数部份为3的最大值为3.000003,那末我们知道List1中应当恰好有3个元素3。类似地,该数组中整数部份为2的最大值为2.000001,这告知我们List1中只有1个元素1。

4. 在List2中履行相同的操作:

List2+(COUNTIF(OFFSET(INDEX(List2,1,1),Arry1,,Arry2,),List2)/10^6)

转换为:

{1;3;3;6;0;0;0;0;0;0;0}+(COUNTIF(OFFSET($B$2,{0;1;2;3;4;5;6;7;8;9;10},,{11;10;9;8;7;6;5;4;3;2;1},),{1;3;3;6;0;0;0;0;0;0;0})/10^6)

转换为:

{1;3;3;6;0;0;0;0;0;0;0}+({1;2;1;1;0;0;0;0;0;0;0}/10^6)

最后得到的结果为:

{1.000001;3.000002;3.000001;6.000001;0;0;0;0;0;0;0}

这样,将原来List2中的元素转换成了由唯一值构成的数组。

5. 现在,可使用MATCH函数来比较这两个数组。IF语句中为FALSE的部份:

SMALL(IF(1-ISNUMBER(MATCH(List1+(COUNTIF(OFFSET(INDEX(List1,1,1),Arry1,,Arry2,),List1)/10^6),List2+(COUNTIF(OFFSET(INDEX(List2,1,1),Arry1,,Arry2,),List2)/10^6),0)),List1),ROWS($1:1))

可以转换为:

SMALL(IF(1-ISNUMBER(MATCH({1.000002;1.000001;2.000001;3.000003;3.000002;3.000001;4.000002;4.000001;5.000001;6.000002;6.000001},{1.000001;3.000002;3.000001;6.000001;0;0;0;0;0;0;0},0)),List1),ROWS($1:1))

转换为:

SMALL(IF(1-ISNUMBER({#N/A;1;#N/A;#N/A;2;3;#N/A;#N/A;#N/A;#N/A;4}),List1),ROWS($1:1))

转换为:

SMALL(IF(1-{FALSE;TRUE;FALSE;FALSE;TRUE;TRUE;FALSE;FALSE;FALSE;FALSE;TRUE},List1),ROWS($1:1))

转换为:

SMALL(IF({1;0;1;1;0;0;1;1;1;1;0},{1;1;2;3;3;3;4;4;5;6;6}),ROWS($1:1))

转换为:

SMALL({1;FALSE;2;3;FALSE; FALSE;4;4;5;6; FALSE },ROWS($1:1))

返回数字:

1

这正是我们需要的。

单元格C3中的公式会转换为:

SMALL({1;FALSE;2;3;FALSE; FALSE;4;4;5;6; FALSE },ROWS($1:2))

返回数字:

2

依此类推。

本案例关键技术:将统计数分配给单元格区域中的每一个值,行之有效的地将含有重复值的单元格区域中的值变成唯一值,这是一项很有用的技术。



选择英雄云云表单=选择更智能的办公工具

>>>>🚀🌟 点击注册 免费试用 更高级的-英雄云企业级云表单 🌟🚀 😃👉🌐>>>>

在现代企业管理中,数据的高效管理和处理至关重要。随着信息技术的不断发展,英雄云云表单已经成为了提高数据录入、管理和分析效率的不可或缺的工具。让我们来深入探讨英雄云-云表单的几大优势。

基础字段:多样性满足业务需求

英雄云云表单中包括了各种基础字段,如单行文本多行文本数字输入框单选框复选框下拉框下拉复选框日期时间分割线等。这些字段的多样性使用户可以根据具体的业务需求,轻松进行文本、数据和时间信息的录入或修改。例如,您可以使用单行文本字段录入员工姓名、产品型号等,或者使用下拉框进行多选,根据不同情况选择更加方便的字段类型。

高级字段:提升工作效率

英雄云云表单还提供了高级字段,如地址图片附件手写签名手机子表关联数据关联查询以及流水号。这些高级字段在基础字段的基础上升级,可帮助用户完成一些琐碎的工作。例如,使用地址字段可以避免逐字打字,而流水号字段可以自动生成规律性的编号,非常适用于合同编号生成等场景。

部门成员字段:精确管理与通讯录的关联

英雄云的部门成员字段允许企业对各个部门的成员进行精确管理。用户可以通过部门成员字段获取通讯录中的部门成员信息,应用于记录报销人、报销部门等场景。这些成员字段还细分为成员单选成员多选,可根据具体需求在通讯录中选择一个或多个成员。

聚合表:数据处理更智能

英雄云聚合表功能用于对已存在的表单数据进行聚合计算,从而得到一张聚合表,后续其他表单可调用聚合表进行数据联动、关联查询和关联数据等操作完成数据处理。这一功能可应用于多种场景,如进销存管理、财务管理和门店零售管理等,帮助企业完成数据处理,提高工作效率。

表单权限设置:灵活管理数据访问

英雄云的表单权限设置允许用户根据企业的具体需求管理表单的访问和操作权限。用户可以根据系统权限或自定义权限对不同成员或团队进行权限设置,以确保数据的安全和合规性。这一功能使企业能够根据变化的业务需求和团队结构,实时调整权限设置。

自定义打印模板:文档输出更便捷

英雄云云表单支持自定义打印模板,可将表单数据转换为可打印的Word文档。用户可以根据自己的需求进行排版和编辑,将产品规格说明书等文档轻松生成。这一功能提供了一种标准化的文档输出方式,简化了信息整理的过程。

综合来看,选择英雄云云表单意味着选择更智能、更灵活、更高效的数据管理工具。无论是提高工作效率,精确管理数据,还是实现数据处理,英雄云云表单都能满足您的多样化需求,助力您的业务发展。

如果您正在寻找一款强大的云表单工具,不妨考虑英雄云,它将为您带来更多的便捷和智能,助您事半功倍。


免责声明:

本网址(www.yingxiongyun.com)发布的材料主要源于独立创作和网友匿名投稿等来源。此处提供的所有信息仅供参考之用。我们致力于提供准确且可信的信息,但不对材料的完整性或真实性作出任何保证。用户应自行验证相关信息的正确性,并对其决策承担全部责任。对于由于信息的错误、不准确或遗漏所造成的任何损失,本网址不承担任何法律责任。本网站所展示的所有内容,如文字、图像、标志、音频、视频、软件和程序等的版权均属于原创作者。如果任何组织或个人认为网站内容可能侵犯其知识产权,或包含不准确之处,请即刻联系我们进行相应处理。

上一篇:excel怎样计算NPV净现值? 净现值npv计算公式的使用教程-英雄云拓展知识分享
下一篇:仅在您肯定显示精度可以保持数据的精确度时才可使用此选项-英雄云拓展知识分享
相关文章
×