filter函数的用法_函数周期表丨筛选丨表丨CALCULATETABLE
CALCULATETABLE函數
CALCULATETABLE函數屬于“篩選”類函數,隸屬于“表函數”。
某種意義上來說,CALCULATETABLE函數其實就是CALCULATE函數的表函數模式。
其核心點都是一致的,根據上下文生成新的上下文。
二者的區別是一個返回的是值,一個返回的是表。
CALCULATETABLE函數內部的運行規律和影響因素與CALCULATE函數如出一轍,這里就不贅述了。感興趣的小伙伴可以看看白茶之前寫的文章《精品丨CALCULATE函數進價知識》,里面有系統的介紹。
用途:構建新的上下文環境,生成一個符合我們需求的表。
語法
DAX= CALCULATETABLE(<表達式>,<篩選器1>,<篩選器2>,…)參數
表達式:必須項,可以是一個表,也可以是表的表達式。
篩選器:可選項可重復,用來過濾條件使用。
返回結果
根據篩選器生成的上下文對表達式進行計算,返回一張表。
例子
模擬數據:
這是白茶隨機模擬的數據。
例子1:
CALCULATETABLE例子1 = CALCULATETABLE ( '例子' )結果:
在不使用任何篩選的情況下,相當于復制。
例子2:
CALCULATETABLE例子2 = CALCULATETABLE ( '例子', '例子'[顏色] = "白" )結果:
這種情況下,作用與FILTER函數的效果類似。
對比:
FILTER對比 = FILTER ( '例子', '例子'[顏色] = "白" )結果:
雖然從明面上看,二者的結果是一致的,但是核心點是完全不一樣的,只能說二者在結果方面有時候是類似的。
稍后白茶會描述一下二者的具體區別,咱們來看看最后一個例子。
例子3:
代碼1:
CALCULATETABLE例子3 = SUMX ( CALCULATETABLE ( '例子', '例子'[日期] < 2015 ), '例子'[銷售] )代碼2:
CALCULATETABLE例子4 = SUMX ( CALCULATETABLE ( '例子', '例子'[日期] < 2015, VALUES ( '例子'[日期] ) ), '例子'[銷售] )結果對比:
從上圖中我們能看出,CALCULATETABLE函數內部優先級與CALCULATE函數是一致。
關于CALCULATETABLE函數的基本用法到這里就結束了。
可是關于CALCULATETABLE函數與FILTER函數的區別還需要進行。
白茶決定通過兩組代碼進行說明:
邏輯1:
CALCULATETABLE邏輯 = CALCULATETABLE ( ADDCOLUMNS (VALUES ( '例子'[顏色] ), "次數", COUNTROWS ( '例子' )), '例子'[顏色] = "白" )結果:
計算結果次數為3。
邏輯2:
FILTER邏輯 = FILTER ( ADDCOLUMNS (VALUES ( '例子'[顏色] ), "次數", COUNTROWS ( '例子' )), '例子'[顏色] = "白" )結果:
次數為21。
這是什么原因造成的呢?
CALCULATETABLE函數在執行的時候,和CALCULATE函數相同,是先改變上下文環境,在新的上下文中計算表達式。而FILTER函數是先迭代第一參數,再查找滿足條件的項目,也就是不生成新的上下文。
邏輯1中,CALCULATETABLE是先進行的篩選,已經把顏色不是“白”都過濾掉了,然后進行第一參數求值。
邏輯2中,ADDCOLUMNS函數本身沒有進行上下文轉換,所以每一行的數據其實都是21,即總計行數。FILTER不具備改變上下文的能力,先執行的第一參數ADDCOLUMNS,然后從里面挑選出“白”的項目,因此呈現的數據是21。
歸根結底,其實還是上下文轉換的問題。
小伙伴們?GET了么?
白茶會不定期的分享一些函數卡片(文件在知識星球[PowerBI丨需求圈])
這里是白茶,一個PowerBI的初學者。
總結
以上是生活随笔為你收集整理的filter函数的用法_函数周期表丨筛选丨表丨CALCULATETABLE的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python绘图教程_pyplot绘图教
- 下一篇: cc2530定时器和捕获比较_STM32