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

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

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

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父子级关系的处理,寻找所有的管理子级。


相关推荐

WPS新增REGEXP函数正则表达式的实践应用1-替换

前面一直讲REGEXP函数正则表达式的提取功能,但REGEXP函数正则表达式的替换功能也是很强大,利用的范围更多,这里对几种替换用法做一下讲解。如下图要将文本中的数据进行插入替换,在后面没有数字的字母...

这几种正则表达式的“字符集合”,想要入门regexp函数,必须了解

前言回顾:大家好,今天我们来分几篇文章讲讲REGEXP正则表达式函数中的正则表达式字符,因为只有掌握了这些字符之后,我们才能结合具体实际需求,编写REGEXP函数的第二参数,将各类符号进行连接组合使用...

regexp函数具有超级替身术,实现数据精准替换

REGEXP函数具有超级替身术,能够实现数据精准替换。学习这个技巧之前,首先我们先来回忆REGEXP函数的基本语法:正则表达式的基础外壳函数(wps版):REGEXP函数是基于正则表达式,对复杂文本进...

REGEXP函数,基础用法请收好

小伙伴们好啊,今天咱们一起学习REGEXP函数的几个基础用法。这个函数是WPS表格中的特有函数之一,能够根据正则表达式对字符串进行提取、判断或替换。函数语法如下:=REGEXP(要处理的字符串,正则表...

regexp是超级替换器,配合textjoin与textsplit,摆平复杂转换

总有小伙伴抱怨:明明学习了大量的函数与用法,怎么到了综合运用的时候却一个也想不到,总是有种相见恨晚的感觉。小编想说的是:想要灵活解决各种问题,掌握各种基础函数的定义与语法固然很重要,更重要的是要自己制...

wps/excel函数技巧:regexp正则替换等号后的第一个字符

所有的等号和数字之间都有一个字母或符号,请试图去掉它,由于字符种类不同,所以使用正则表达式效果最好:=REGEXP(A2,"=\K.",2)第二个参数是正则表达式,=.*?意图是匹配...

DeepSeek R1 高效微调医疗大模型实战,第二步准备环境下载模型文件

一、模型微调所需硬件与服务器环境搭建大模型微调属于大模型进阶类技术,不同于普通的模型对话或搭建基础应用,微调往往需要一定的软硬件条件支持。大模型微调所需硬件一览硬件方面,不同尺寸模型、不同精度微调时所...

从零开始打造云端AI管理调度平台(一)创建django项目

最近闲来无事,想着把自己工作正在做的一个项目做一个简单的分享与实战教程,该项目不困难但是由于涉及要素过多所以比较复杂。所以这里分享出来也是为了帮助新手小白能在实战当中快速了解python知识。主要内容...

零代码编程:用ChatGPT写Python程序爬取并处理网页数据

下面这个网站页面,列出了很多AI网站,但是是以图片方式列出,点击图片会跳转到网站。怎么能把这些AI网站名称、AI网站网址自动爬取下来保存成excel文件呢?首先,在chrome浏览器中点击右键,点击i...

YOLOv8入门篇--YOLOv8的安装和使用

作者的系统环境是:笔记本:ThindPadP520OS:win11显卡:QuadroP5201、安装anacondaanaconda是什么?为什么要安装anaconda?anaconda是一个py...

在Windows中快速搭建OpenVINO notebook运行环境

什么是OpenVINOnotebook?OpenVINOnotebook是一系列现成可用的,Jupyternotebook形式的范例程序,可以帮助AI开发者快速学习并掌握OpenVINOAP...

LabVIEW 与 Python 融合:打造强大测试系统的利器

在现代测试系统开发领域,LabVIEW和Python各自凭借独特优势占据重要地位。LabVIEW以图形化编程、仪器控制和实时系统开发能力见长;Python则凭借丰富的库资源、简洁语法和强大数...

Python多环境管理神器(pyenv)

下面我们来介绍一个python多环境管理神器pyenvpyenvpyenv主要用来对Python解释器进行管理,可以管理系统上的多个版本的Python解释器。它的主要原理就是将新的解释器路径...

一文吃透Python虚拟环境

摘要在Python开发中,虚拟环境是一种重要的工具,用于隔离不同项目的依赖关系和环境配置。本文将基于windows平台介绍四种常用的Python虚拟环境创建工具:venv、virtualenv、pip...

Intel集成显卡GPU部署Comfyui完整过程

Comfyui本地部署,网上有很多大佬提供了完整的Comfyui压缩包,但下载下来运行总是有各种问题,一直没有跑起来,那就重头自己安装一个吧,同时解决支持Intel集成显卡的问题。笔记本配置下载Com...