日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

filter函数的用法_函数周期表丨筛选丨表丨CALCULATETABLE

發(fā)布時間:2025/3/20 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 filter函数的用法_函数周期表丨筛选丨表丨CALCULATETABLE 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

CALCULATETABLE函數(shù)

CALCULATETABLE函數(shù)屬于“篩選”類函數(shù),隸屬于“表函數(shù)”。

某種意義上來說,CALCULATETABLE函數(shù)其實就是CALCULATE函數(shù)的表函數(shù)模式。

其核心點都是一致的,根據(jù)上下文生成新的上下文。

二者的區(qū)別是一個返回的是值,一個返回的是表。

CALCULATETABLE函數(shù)內(nèi)部的運行規(guī)律和影響因素與CALCULATE函數(shù)如出一轍,這里就不贅述了。
感興趣的小伙伴可以看看白茶之前寫的文章《精品丨CALCULATE函數(shù)進價知識》,里面有系統(tǒng)的介紹。

用途:構(gòu)建新的上下文環(huán)境,生成一個符合我們需求的表。

語法

DAX= CALCULATETABLE(<表達式>,<篩選器1>,<篩選器2>,…)

參數(shù)

表達式:必須項,可以是一個表,也可以是表的表達式。

篩選器:可選項可重復(fù),用來過濾條件使用。

返回結(jié)果

根據(jù)篩選器生成的上下文對表達式進行計算,返回一張表。

例子

模擬數(shù)據(jù):

這是白茶隨機模擬的數(shù)據(jù)。

例子1:

CALCULATETABLE例子1 = CALCULATETABLE ( '例子' )

結(jié)果:

在不使用任何篩選的情況下,相當于復(fù)制。

例子2:

CALCULATETABLE例子2 = CALCULATETABLE ( '例子', '例子'[顏色] = "白" )

結(jié)果:

這種情況下,作用與FILTER函數(shù)的效果類似。

對比:

FILTER對比 = FILTER ( '例子', '例子'[顏色] = "白" )

結(jié)果:

雖然從明面上看,二者的結(jié)果是一致的,但是核心點是完全不一樣的,只能說二者在結(jié)果方面有時候是類似的。

稍后白茶會描述一下二者的具體區(qū)別,咱們來看看最后一個例子。

例子3:

代碼1:

CALCULATETABLE例子3 = SUMX ( CALCULATETABLE ( '例子', '例子'[日期] < 2015 ), '例子'[銷售] )

代碼2:

CALCULATETABLE例子4 = SUMX ( CALCULATETABLE ( '例子', '例子'[日期] < 2015, VALUES ( '例子'[日期] ) ), '例子'[銷售] )

結(jié)果對比:

從上圖中我們能看出,CALCULATETABLE函數(shù)內(nèi)部優(yōu)先級與CALCULATE函數(shù)是一致。

關(guān)于CALCULATETABLE函數(shù)的基本用法到這里就結(jié)束了。


可是關(guān)于CALCULATETABLE函數(shù)與FILTER函數(shù)的區(qū)別還需要進行。

白茶決定通過兩組代碼進行說明:

邏輯1:

CALCULATETABLE邏輯 = CALCULATETABLE ( ADDCOLUMNS (VALUES ( '例子'[顏色] ), "次數(shù)", COUNTROWS ( '例子' )), '例子'[顏色] = "白" )

結(jié)果:

計算結(jié)果次數(shù)為3。

邏輯2:

FILTER邏輯 = FILTER ( ADDCOLUMNS (VALUES ( '例子'[顏色] ), "次數(shù)", COUNTROWS ( '例子' )), '例子'[顏色] = "白" )

結(jié)果:

次數(shù)為21。

這是什么原因造成的呢?

CALCULATETABLE函數(shù)在執(zhí)行的時候,和CALCULATE函數(shù)相同,是先改變上下文環(huán)境,在新的上下文中計算表達式。
而FILTER函數(shù)是先迭代第一參數(shù),再查找滿足條件的項目,也就是不生成新的上下文。

邏輯1中,CALCULATETABLE是先進行的篩選,已經(jīng)把顏色不是“白”都過濾掉了,然后進行第一參數(shù)求值。

邏輯2中,ADDCOLUMNS函數(shù)本身沒有進行上下文轉(zhuǎn)換,所以每一行的數(shù)據(jù)其實都是21,即總計行數(shù)。FILTER不具備改變上下文的能力,先執(zhí)行的第一參數(shù)ADDCOLUMNS,然后從里面挑選出“白”的項目,因此呈現(xiàn)的數(shù)據(jù)是21。

歸根結(jié)底,其實還是上下文轉(zhuǎn)換的問題。

小伙伴們?GET了么?

白茶會不定期的分享一些函數(shù)卡片(文件在知識星球[PowerBI丨需求圈])

這里是白茶,一個PowerBI的初學者。

總結(jié)

以上是生活随笔為你收集整理的filter函数的用法_函数周期表丨筛选丨表丨CALCULATETABLE的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。