首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >动力查询(M语言) 50天移动平均

动力查询(M语言) 50天移动平均
EN

Stack Overflow用户
提问于 2019-03-25 12:36:55
回答 2查看 3.1K关注 0票数 0

我有一个产品清单,并希望得到一个50天的简单移动平均值其体积使用的电力查询(M)。

该表按产品名称和日期进行排序。我添加了一个自定义列并应用了下面的代码。

代码语言:javascript
复制
if [date] >= #date(2018,1,29)
then List.Average(List.Range(Source[Volume],[Volume]-1,-50))
else ""

由于它已经按日期和名称排序,所以应用了一个if语句,其中日期作为标准/筛选器。但是,会出现一个错误,即

表中找不到“卷”列。

我希望在power查询中增加一个列,每个产品的容量为50天移动平均值。如果date大于或等于2018年1月29日,则计算。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-03-31 10:00:58

终于来了!找到了解决办法。首先,按产品详情请参阅本篇文章。应用索引,然后在没有标准的情况下再次索引(索引所有行),然后应用下面的代码

= Table.AddColumn(#"Previous Step", "Volume SMA(50)", each if [Index_byProduct] >= 50 then List.Average(List.Range(#"Previous Step"[Volume], ([Index_All]-50),50)) else 0),

对于大型数据集,建议在索引展开步骤之后使用Table.Buffer函数来提高PQ的计算速度。

票数 0
EN

Stack Overflow用户

发布于 2019-03-25 15:33:48

我们不知道您的列是什么,但假设您在Source中有产品、日期和卷,这将根据每个日期对相同产品的最后50天的成交量进行平均处理,并将其放入新的列中

代码语言:javascript
复制
AvgAmountAdded = Table.AddColumn(Source, "AverageAmount", (i) => List.Average(Table.SelectRows(Source, each ([product] = i[product] and [date]<=i[date] and [date]>=Date.AddDays(i[date],-50)))[volume]), type number)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55337952

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档