让我们一起探索一下这些藏在excel自动排序中的“小秘密”。-英雄云拓展知识分享
3644
2024-12-09
有时候,我们希望将公式利用于一组值而不是一个值,这可以简单地将公式作为数组公式(按Ctrl+Shift+Enter键)来实现。但是,其实不是所有公式都能如此轻松地产生这样的效果,有些公式很“顽强”地抵制任何试图强迫让它们返回数组的尝试。本文将探讨一些技术,除数组情势的输入外,可以帮助强迫到达想要的结果。
举例来看,下图1中单元格区域A1:A5是要使用的数据,右边的数组公式并没有给出想要的结果。(特别说明:示例纯洁是为了演示我们要讲授的技术。)
图1
第一个公式使用了INDIRECT函数和ADDRESS函数组合来求单元格区域A1:A5中的数值之和。明显,诸以下面的非数组公式:
=INDIRECT(ADDRESS(1,1))
解析成:
=INDIRECT(“$A$1”)
结果为:
9.2
因此,这种情况下,我们可能希望使用数组公式将这类公式构造利用于多个单元格。但是,使用数组输入后的公式:
=SUM(INDIRECT(ADDRESS({1,2,3,4,5},1)))
其实不会像你所希望的那样解析,而是转换为:
=SUM(INDIRECT(“$A$1”))
ADDRESS函数仅仅处理了数组中的第一个元素,就像我们将其作为非数组公式输入一样。
在这类情况下,所需的强迫其实不是特别复杂,也不需要触及OFFSET函数或INDEX函数的构造。事实上,所需要做的就是包括一个小的N函数:
=SUM(N(INDIRECT(ADDRESS({1,2,3,4,5},1))))
解析为:
=SUM(N(INDIRECT({“$A$1″,”$A$2″,”$A$3″,”$A$4″,”$A$5”})))
解析为:
=SUM(N({9.2,1.1,5.5,7.4,3.3})))
即:
=SUM({9.2,1.1,5.5,7.4,3.3})
结果是:
26.5
在这类公式结构中使用N函数其实不是为了将其用作函数(广义上讲,是在可能的情形下将非数字转换为数字),而是由于它具有附带的(也是非常有用的)特质:能够促使其他函数操作一组数值数组,例如此处的ADDRESS函数不能操作数组的情况。
固然,我们应当意想到我们使用N函数是由于此处的值是由数字组成。但是,如果我们想使用带有INDIRECT和ADDRESS函数的公式构造生成一个数组,但是其值不是数字,而是文本,并且所得到的数组不被求和而是传递给其他函数,该怎样办?
荣幸的是,Excel为提供了一个与N函数具有类似功能的T函数。与N函数一样,T函数一样具有强迫返回数组的特质。N函数用于数字,T函数用于文本值。
举例来看,如果单元格区域A1:A5中的值是“A”、”B“、”C“、”D”、“E”,那末公式:
=LOOKUP(REPT(“z”,255),T(INDIRECT(ADDRESS({1,2,3,4,5},1))))
LOOKUP函数也具有强迫返回数组的特质。公式解析为:
=LOOKUP(REPT(“z”,255),T(INDIRECT({“$A$1″,”$A$2″,”$A$3″,”$A$4″,”$A$5”})))
解析为:
=LOOKUP(REPT(“z”,255),T({“A”,”B”,”C”,”D”,”E”}))
解析为:
=LOOKUP(REPT(“z”,255),{“A”,”B”,”C”,”D”,”E”})
结果为:
E
但是,使用N或T函数强迫转换为数组不适用于所有函数,以包括DEC2BIN函数的公式为例:
=SUM(DEC2BIN(A1:A5))
解析为:
=SUM(#VALUE!)
结果为:
#VALUE!
这不是我们想要的结果。
试着在其中添加N函数:
=SUM(N(DEC2BIN(A1:A5)))
情况其实不好,由于DEC2BIN函数谢绝N函数试图强迫返回数组的尝试,解析为:
=SUM(N(#VALUE!))
那末,在这些情况下,我们需要寻求替换方法来强迫得到我们所需的数组处理。一种方法是使用OFFSET函数,以下所示:
=SUM(0+DEC2BIN(OFFSET(A1,ROW(A1:A5)-MIN(ROW(A1:A5)),,,)))
解析为:
=SUM(0+DEC2BIN(OFFSET(A1,{1;2;3;4;5}⑴,,,)))
解析为:
=SUM(0+DEC2BIN(OFFSET(A1,{0;1;2;3;4},,,)))
解析为:
=SUM(0+DEC2BIN({9.2;1.1;5.5;7.4;3.3}))
解析为:
=SUM(0+{“1001″;”1″;”101″;”111″;”11”})
解析为:
=SUM({1001;1;101;111;11})
结果为:
1225
再提示一下,虽然以这类方式求2进制之和其实不实用,但我们这里重在用其来演示公式技术。
这类包括OFFSET函数的公式技术可用于多个函数,这些函数最初谢绝数组输入。在第3个示例中,使用了DOLLARDE函数,公式以下:
=SUM(DOLLARDE(A1:A5,2))
结果为#VALUE!,而公式:
=SUM(DOLLARDE(OFFSET(A1,ROW(A1:A5)-MIN(ROW(A1:A5)),,,),2))
可以正确地处理数组,并得到想要的结果32.5。
第4个示例:
=IMSUM(COMPLEX(A1:A5,1))
结果返回毛病值,而公式:
=IMSUM(COMPLEX(OFFSET(A1,ROW(A1:A5)-MIN(ROW(A1:A5)),,,),1))
解析为:
=IMSUM(COMPLEX(OFFSET(A1,{0;1;2;3;4},,,),1))
解析为:
=IMSUM(COMPLEX({9.2;1.1;5.5;7.4;3.3},1))
解析为:
=IMSUM({“9.2+i”;”1.1+i”;”5.5+i”;”7.4+i”;”3.3+i”})
得到想要的结果:
26.5+5i
但是,这类包括OFFSET函数的公式技术其实不是使我们能够强迫这些“固执”的函数产生数组返回值的唯一方法。在《Excel公式技能03:INDEX函数,给公式提供数组》中,讲授了从INDEX函数强迫返回数组的技术,在这里也能够使用。上述示例公式的等效的INDEX函数构造以下:
=SUM(0+DEC2BIN(INDEX(A1:A5,N(IF(1,ROW(A1:A5)-MIN(ROW(A1:A5))+1)))))
=SUM(DOLLARDE(INDEX(A1:A5,N(IF(1,ROW(A1:A5)-MIN(ROW(A1:A5))+1))),2))
=IMSUM(COMPLEX(INDEX(A1:A5,N(IF(1,ROW(A1:A5)-MIN(ROW(A1:A5))+1))),1))
事实上,由于INDEX函数是非易失性的,所以可以说这个版本的公式更优于OFFSET版本的公式,虽然多使用了两个函数N和IF。
现在,看看最后一个示例,该示例触及到少量使用的CELL函数。在这里,我们尝试与第一个示例中的INDIRECT/ADDRESS函数组合类似的方式使用此函数,即指定参数info_type为“address”来取得要传递给SUM的一组单元格援用(固然是在经过INDIRECT函数处理后)。公式:
=SUM(INDIRECT(CELL(“address”,A1:A5)))
会解析为:
=SUM(INDIRECT(“$A$1”))
这不是我们想要的结果。
像上文介绍的那样,先尝试在公式中添加OFFSET函数来解决这个问题:
=SUM(INDIRECT(CELL(“address”,OFFSET(A1,ROW(A1:A5)-MIN(ROW(A1:A5)),,,))))
这次仍没有到达我们料想的结果,虽然是数组公式输入,但这里的OFFSET函数并未操作ROW函数构造中的所有元素。事实上,公式中的:
ROW(A1:A5)-MIN(ROW(A1:A5))
我们希望返回的结果是:
{0;1;2;3;4}
但实际上不是这样,结果是:
0
等价于:
ROW(A1)-MIN(ROW(A1:A5))
只是处理了ROW(A1:A5)数组中的第一个元素。
奇怪!完全不是我们期望的数组公式,也不肯定CELL函数谢绝接受生成数组输入的缘由。不知道有无人知道?
这样,现在需要采取更多的强迫办法:
=SUM(INDIRECT(CELL(“address”,OFFSET(A1,N(INDEX(ROW(A1:A5)-MIN(ROW(A1:A5)),,)),,,))))
解析为:
=SUM(INDIRECT(CELL(“address”,OFFSET(A1,N(INDEX({0;1;2;3;4},,)),,,))))
解析为:
=SUM(INDIRECT(CELL(“address”,OFFSET(A1,N({0;1;2;3;4}),,,))))
解析为:
=SUM(INDIRECT(CELL(“address”,OFFSET(A1,{0;1;2;3;4},,,))))
解析为:
=SUM(INDIRECT({“$A$1″;”$A$2″;”$A$3″;”$A$4″;”$A$5”}))
这样,就与第一个示例一样了。
值得记住的是,不管强迫性需求的程度如何,不管它是不是必定触及一个、两个乃至3个额外的函数,这些强迫性函数很大程度上来自于INDEX、N(或T)和OFFSET函数的组合,并使用一些特定的语法。
>>>>🚀🌟 点击注册 免费试用 更高级的-英雄云企业级云表单 🌟🚀 😃👉🌐>>>>
在现代企业管理中,数据的高效管理和处理至关重要。随着信息技术的不断发展,英雄云的云表单已经成为了提高数据录入、管理和分析效率的不可或缺的工具。让我们来深入探讨英雄云-云表单的几大优势。
基础字段:多样性满足业务需求
英雄云的云表单中包括了各种基础字段,如单行文本、多行文本、数字输入框、单选框、复选框、下拉框、下拉复选框、日期时间、分割线等。这些字段的多样性使用户可以根据具体的业务需求,轻松进行文本、数据和时间信息的录入或修改。例如,您可以使用单行文本字段录入员工姓名、产品型号等,或者使用下拉框进行多选,根据不同情况选择更加方便的字段类型。
高级字段:提升工作效率
英雄云的云表单还提供了高级字段,如地址、图片、附件、手写签名、手机、子表、关联数据、关联查询以及流水号。这些高级字段在基础字段的基础上升级,可帮助用户完成一些琐碎的工作。例如,使用地址字段可以避免逐字打字,而流水号字段可以自动生成规律性的编号,非常适用于合同编号生成等场景。
部门成员字段:精确管理与通讯录的关联
英雄云的部门成员字段允许企业对各个部门的成员进行精确管理。用户可以通过部门成员字段获取通讯录中的部门成员信息,应用于记录报销人、报销部门等场景。这些成员字段还细分为成员单选和成员多选,可根据具体需求在通讯录中选择一个或多个成员。
聚合表:数据处理更智能
英雄云的聚合表功能用于对已存在的表单数据进行聚合计算,从而得到一张聚合表,后续其他表单可调用聚合表进行数据联动、关联查询和关联数据等操作完成数据处理。这一功能可应用于多种场景,如进销存管理、财务管理和门店零售管理等,帮助企业完成数据处理,提高工作效率。
表单权限设置:灵活管理数据访问
英雄云的表单权限设置允许用户根据企业的具体需求管理表单的访问和操作权限。用户可以根据系统权限或自定义权限对不同成员或团队进行权限设置,以确保数据的安全和合规性。这一功能使企业能够根据变化的业务需求和团队结构,实时调整权限设置。
自定义打印模板:文档输出更便捷
英雄云的云表单支持自定义打印模板,可将表单数据转换为可打印的Word文档。用户可以根据自己的需求进行排版和编辑,将产品规格说明书等文档轻松生成。这一功能提供了一种标准化的文档输出方式,简化了信息整理的过程。
综合来看,选择英雄云的云表单意味着选择更智能、更灵活、更高效的数据管理工具。无论是提高工作效率,精确管理数据,还是实现数据处理,英雄云的云表单都能满足您的多样化需求,助力您的业务发展。
如果您正在寻找一款强大的云表单工具,不妨考虑英雄云,它将为您带来更多的便捷和智能,助您事半功倍。
免责声明:
本网址(www.yingxiongyun.com)发布的材料主要源于独立创作和网友匿名投稿等来源。此处提供的所有信息仅供参考之用。我们致力于提供准确且可信的信息,但不对材料的完整性或真实性作出任何保证。用户应自行验证相关信息的正确性,并对其决策承担全部责任。对于由于信息的错误、不准确或遗漏所造成的任何损失,本网址不承担任何法律责任。本网站所展示的所有内容,如文字、图像、标志、音频、视频、软件和程序等的版权均属于原创作者。如果任何组织或个人认为网站内容可能侵犯其知识产权,或包含不准确之处,请即刻联系我们进行相应处理。
发表评论
暂时没有评论,来抢沙发吧~