如何解决切片器过滤表格内的列表
+---------+--------------+
| tag | val |
+---------+--------------+
| [a,b,c] | 1 |
| [a,e] | 2 |
| [f,g] | 3 |
| [e,f] | 4 |
+---------+--------------+
can I create a slicer that when selected will still filter the item inside the list of the tag column?
例如。我选择过滤器“a”,它将显示 1 和 2。“e”将过滤 2 和 4,“f”将过滤 3 等。
解决方法
您可以创建一个使用 PATHCONTAINS 函数的度量(返回 1/0)。我们需要删除方括号并替换逗号以管道“|”;您可以将此度量放入表格/矩阵可视化中的过滤器窗格 https://dax.guide/pathcontains/
ForFilter =
var __selectedTag = SELECTEDVALUE(disconnected[tagList])
var __tags = SELECTEDVALUE('Table'[Tag])
var __path = SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(__tags,","|"),"[",""),"]","")
return
IF(PATHCONTAINS(__path,__selectedTag),1,0)
编辑: 多选版本
var __string = CONCATENATEX( VALUES(disconnected[tagList]),disconnected[tagList],"|")
var __tags = SELECTEDVALUE('Table'[Tag])
var __path = SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(__tags,"")
VAR Table0 =
SELECTCOLUMNS(
TOPN(1,SELECTCOLUMNS(
ADDCOLUMNS (
GENERATE (
ROW ( "tag",__path,"Text",__string ),VAR TokenCount =
PATHLENGTH ([Text] )
RETURN
GENERATESERIES ( 1,TokenCount )
),"Word",PATHITEM ([Text],[Value] )
),IF(PATHCONTAINS([tag],[Word]),0),"Tag",[tag],"Values",[Value]
),[Word],DESC,[Values]),"Bool",[Word])
return
Table0
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。