0

0

ExcelSCAN与LAMBDA如何创建自定义移动平均函数_SCAN实现任意窗口期移动平均计算

蓮花仙者

蓮花仙者

发布时间:2025-11-29 09:58:09

|

781人浏览过

|

来源于php中文网

原创

使用SCAN与LAMBDA函数可创建任意窗口期的移动平均,无需辅助列。通过SCAN遍历数据并用LAMBDA维护状态,结合SEQUENCE与INDEX实现高效滑动窗口计算,最终封装为可复用的MOVING_AVERAGE函数,支持动态数组实时更新。

excelscan与lambda如何创建自定义移动平均函数_scan实现任意窗口期移动平均计算

在Excel中,使用SCAN与LAMBDA函数可以灵活创建自定义的移动平均函数,尤其适用于任意窗口期的动态计算。传统方法如OFFSET或AVERAGE常受限于固定结构,而SCAN配合LAMBDA提供了更简洁、可复用的解决方案。

理解SCAN与LAMBDA的基本作用

SCAN函数用于遍历数组并累积中间结果,其语法为SCAN(初始值, 数组, LAMBDA)。它会返回一个与原数组等长的结果数组,适合逐元素处理场景。

LAMBDA允许你定义自定义函数,无需VBA,直接在公式中封装逻辑。结合两者,可以在不使用辅助列的情况下实时计算移动平均。

构建任意窗口期的移动平均函数

核心思路是:利用SCAN记录最近N个数据点,并在每个位置计算其平均值。虽然SCAN本身不能直接滑动窗口,但可通过LAMBDA维护一个“状态”来模拟窗口行为。

例如,假设数据在A2:A100,想计算窗口期为3的移动平均:

  • 使用SCAN从第一个数据开始累积处理
  • 在LAMBDA中保留最近的3个值(通过数组拼接与截取)
  • 当累计数量不足窗口期时返回空或直接平均,达到后取最后N项均值

具体公式如下:

Tellers AI
Tellers AI

Tellers是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。

下载
=DROP( SCAN("", A2:A100, LAMBDA(acc, x, LET( current, IF(ISNUMBER(acc), HSTACK(acc, x), x), len, COLUMNS(current), window, IF(len >= 3, INDEX(current,, SEQUENCE(,3,, -2)), current), AVERAGE(window) ) )), , -1)

说明:此例仅示意逻辑,实际需更精确控制窗口长度。更优方式是用INDEX和ROW组合追踪位置。

简化并通用化为可复用的LAMBDA函数

将逻辑封装成命名函数,比如叫MOVING_AVERAGE

  • 参数包括数据范围和窗口大小(n)
  • 使用SEQUENCE生成索引,结合INDEX逐行提取前n个值
  • 避免使用HSTACK频繁扩展数组,提升性能

推荐实现方式:

=LAMBDA(data, n, BYROW(SEQUENCE(ROWS(data)), LAMBDA(i, IF(i

这个版本虽未使用SCAN,但在多数情况下更稳定高效。若坚持用SCAN模拟过程流,可结合计数器与条件判断,但复杂度更高,实用性略低。

基本上就这些。对于大多数用户,BYROW + SEQUENCE方式更直观可靠;SCAN + LAMBDA更适合需要状态传递的复杂累积场景。掌握这两种模式,就能应对各种动态计算需求。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

752

2023.08.22

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

204

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

190

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

49

2026.01.05

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

204

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

190

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

49

2026.01.05

excel对比两列数据异同
excel对比两列数据异同

Excel作为数据的小型载体,在日常工作中经常会遇到需要核对两列数据的情况,本专题为大家提供excel对比两列数据异同相关的文章,大家可以免费体验。

1387

2023.07.25

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 12.6万人学习

550W粉丝大佬手把手从零学JavaScript
550W粉丝大佬手把手从零学JavaScript

共1课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号