百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

excel函数技巧:NO38函数之王reduce函数

itomcoil 2025-03-04 12:43 15 浏览

reduce函数是lambda函数类的集大成者,学会它基本掌握了循环类lambda的精髓,它可以以替代map\scan\byrow\bycol等函数,从而减少需要记忆函数的数量。

参数一:初始数组。指定初始的数组,对于数值累加,一般设定为0,对于循环递归,一般设定为最早的数据。


其它一般设定为空值,最后再用drop去掉。

参数二:需要遍历的数组,一般是操作对象,同时配合offset可以关联更多的操作对象。也可以不是操作对象,仅仅是循环次数。

如,求10连续加10个1的和,公式为

=REDUCE(10,SEQUENCE(10),LAMBDA(X,Y,SUM(X)+1)),结果为20,变量y的作用仅为控制SUM(X)+1执行的次数。

参数三:函数体,由lambda变量及计算部分组成,能够完成各种各样的计算或者结果输出。

优点:

1、基本实现了循环的所有的功能,使函数的操作向编程迈进坚实一步。

2、功能非常全面,看似是累加器函数,实际上基本可以实现函数的所有功能,很多功能还在开发中。

3、实现整体表格的输出,不同于以前只能形成几个数据再拖动形成表格中的一部分,reduce函数配合vsatck和hstack实现了自定义表格的功能。

缺点:

1、复杂,需要很好的理解各部的作用,特别是lambda内表达式的使用。

2、繁琐,如初始值很多时候没有作用还需要用drop去掉,lambda变量自定义很多时候都一样但不能简化。

3、有用的配合类函数缺少,如reduce就是为了大规模数据才用的,但数据规模上来后对于数据的概要性函数应该补上。

4、对于错误值的处理方式过于简单,基本就是整个函数返回错误值,要知道可能只是好几千行结果里的几行出现问题。

  • 功能:

1、累加,形成数组最后的累加值,配合vstack可以形成过程累加值,这样就与scan函数功能相同。

示例:=REDUCE(,{1,2,3,4},LAMBDA(x,y,VSTACK(x,TAKE(x,-1)+y))),结果为1,3,6,10。

2、加速函数的运算过程,节省书写过程,如substitute函数的递归套用,filter函数的多值调用,这与map的功能产生的重叠。xlookup函数的多值调用及多值返回等。

3、输出整个表单,配合vstack和hstack函数完成新格的输出,可以一次输出多个表格。



由明细生成对账单:

=IFERROR(REDUCE("",UNIQUE(明细!B4:B20),LAMBDA(x,y,VSTACK(x,VSTACK("",A4:K4,HSTACK(A5,y),A6:K6,HSTACK(SEQUENCE(ROWS(FILTER(HSTACK(明细!C4:J20,明细!O4:P20),明细!B4:B20=y))),FILTER(HSTACK(明细!C4:J20,明细!O4:P20),明细!B4:B20=y)))))),"")

4、逆透视,根据要求形成新的切片。主要是数据的提取及位置变换方面。


原数据按部门分类自动按每页30行进行分页打印,并在打印时内容不满30行时,页面空白的位置能否按格式自动填充网格至30行。

=REDUCE(原数据!A1:H1,UNIQUE(原数据!A2:A109),LAMBDA(x,y,VSTACK(x,LET(
i,FILTER(原数据!$A$2:$H$109,原数据!A2:A109=y,""),
IF(ROWS(i)<30,VSTACK(i,EXPAND(" ",30-ROWS(i),8," ")),i)
))))


=REDUCE({"姓名","科目","年级","班级"},C2:E10,LAMBDA(x,y,LET(

i,INDEX(A1:E1,1,COLUMN(y)),

j,INDEX(A1:A10,ROW(y)),

k,TEXTJOIN(",",1,FILTER(B:B,INDEX(A:E,,COLUMN(y))=y)),

UNIQUE(VSTACK(x,HSTACK(y,i,j,k)))

)))


5、配合offset函数操作行、列、一个区域的表格区域进行运算,形成相要的结果。


=REDUCE(A1:Q1,M2,LAMBDA(x,y,VSTACK(x,IF(y=22,IFS(COLUMN(A:Q)=13,U3:U7,COLUMN(A:Q)=17,Q2*V3:V7,TRUE,OFFSET(y,,-12,,16)),""))))

6、BOM父子级关系的处理,寻找所有的管理子级。


相关推荐

编程学子看过来,竞赛刷题网站推荐

2022年编程竞赛已经公布,想要在今年取得竞赛成绩的学生,一定要把握寒假时间,学习知识的同时通过刷题,巩固所学知识,提升解题能力。小编为大家推荐几个刷题网站,想要竞赛的学生一定不要错过。USACO美国...

给大家推荐些好的c语言代码的网站

C语言,那就来推荐几个吧,部分含有C++:1、TheLinuxKernelArchives(kernel.org)Linux内核源码,仅限于C,但内核庞大,不太适合新手;2、redis(redi...

推荐几个编程入门学习网站_比较好的编程自学网站

有一些刚上大学的朋友和想对编程感兴趣的朋友经常会让我推荐学习网站,下面几个是我认为零基础学编程比较好的网站,希望大家都有收获!1.W3schoolhttp://www.w3school.com.c...

10个最值得收藏的编程学习网站_有什么学编程的网站

程序员是一个需要不断学习的职业。幸运的是,在这个互联网时代,知识就在那里,等着我们去获取。以下我列举一些免费的编程学习网站包含多个开发语言Java、php、html、javascript等多个。1、h...

6个超酷的练习算法,学习编程的网站

在不了解算法的前提下,您无法通过Google或Facebook的采访。那么为什么不现在学习。我是一位拥有15年以上经验的程序员。从高中开始的第一年,我在算法上学习和工作很多。在我毕业之前,我一直...

在线 python 编程的网站_python3在线编程,python3在线编译器,在线编辑器

以下是一些提供在线Python编程环境的网站:1.Repl.it:Repl.it提供了一个多语言在线编程平台,您可以使用它在任何地方编写、运行、共享代码。Repl.it支持多种编程语言,包括Pyth...

推荐 7 个能过招全球程序员的编程挑战网站,欢迎挑战!

作为程序员的你,是不是经常估不准自己的编程水平?下面推荐7个能过招全球程序员的编程挑战网站,助你磨练技巧,提升技能,最终问鼎代码江湖!1.HackerRank你可以参加各种编码竞赛,比如算法、数学...

盘点 20 个编程学习教程网站,建议收藏

欢迎关注@程序员柠檬橙私信回复「1024」获取海量编程学习资源!如果你想学习编程,现在互联网这么方便,不用着急报名培训班,有很多高质量的编程学习资源网站可供你学习,程序员日常浏览的技术教程网站有哪些...

Flask 数据可视化_flourish数据可视化

数据可视化是数据处理中的重要部分,前面我们了解了Flask的开发和部署,如何用Flask做数据可视化呢?今天我们来了解一下。Python语言极富表达力,并且拥有众多的数据分析库和框架,是数据...

【python 工具】selenium 浏览器操作

selenium的安装步骤:1.安装selenium,打开cmd控制台pipinstallselenium2.安装驱动程序(我这里安装的是chromedriver),用来启动chrome浏览器...

可视化爬虫工具,EasySpider软件体验

现在提起爬虫,大家可能会联想到Python语言,然后就是各种使用无头浏览器去网页上爬取数据,使用Python的过程相较于使用其他语言来说,简单了不少。但毕竟是编程语言,也需要去学习来适配各种网...

cursor+mcp+playwright,让AI给你推荐五一旅游胜地

阅读本文前提当你已了解mcp是什么,若不知,猛击:https://github.com/modelcontextprotocol/servers。最近有个小需求,根据用户输入内容,使用大模型来理解用户...

Cursor+Claude+Playwright:AI 让自动化测试效率暴涨,快到飞起!

一、引言随着AI时代的到来,软件测试变得越来越复杂,如何高效、准确地进行自动化测试成了每一个开发团队必须面对的问题。在日常工作中,测试工作常常面临各种挑战,比如功能复杂、需求频繁变更、时间紧迫等。传统...

推荐一个检测 JS 内存泄漏的神器_js内存泄漏的几种情况

大家好,我是Echa哥。作为一名Web应用程序开发者,排查和修复JavaScript代码的内存泄漏一直是最困扰我的问题之一。最近,Meta开源了一款检测JavaScript代码内存泄漏...

Python+Playwright自动化实战:高效爬虫全攻略

一、为什么选择Playwright?在信息爆炸的时代,数据获取能力直接决定内容生产效率。Playwright作为微软开源的新型自动化工具,凭借以下优势成为技术创作者的新宠:支持Chromium/Web...