Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.

Reply
Syndicate_Admin
Administrator
Administrator

¿Usas SWITCH dentro de KEEPFILTERS y IN?

¿Es posible cambiar la lista dentro de una cadena KEEPFILTERS IN?
Parece que no puedo hacer que funcione.

Quiero que mi usuario final pueda realizar una selección de parámetros, y esa selección cambia la lista que la instrucción KEEPFILTERS examina después de IN.

justinh_0-1709929770319.png

1 ACCEPTED SOLUTION

Esta versión incluso mantiene los "KeepFilters" en su lugar:

VAR _ConversionType = [Selected Conversion Type]
VAR _Table = 
	CALCULATETABLE(
		SUMMARIZE(
			b_Assortment_Bridge,
			b_Assortment_Bridge[Inventory_Key],
			b_Assortment_Bridge[Assortment StdCost Ratio],
			b_Assortment_Bridge[Assortment Flag]
		),
		KEEPFILTERS( 
			SWITCH(
				_ConversionType,
				"Both",
					b_Assortment_Bridge[Assortment Flag] IN {"", "Assortment SKU", "Set - Component SKU"},
				"Assortments",
					b_Assortment_Bridge[Assortment Flag] IN {"", "Assortment SKU", "Set - Inventory SKU"},
				"Sets",
					b_Assortment_Bridge[Assortment Flag] IN {"", "Set - Component SKU"},
				"Off",
					b_Assortment_Bridge[Assortment Flag] IN {"", "Set - Inventory SKU"}
			)
		)
	)
VAR _Measure = 
	SUMX(
		_Table,
		CALCULATE( [.Sales - Selling SKUs] ) * [Assortment StdCost Ratio]
	)

RETURN
	_Measure

View solution in original post

4 REPLIES 4
Syndicate_Admin
Administrator
Administrator

No es sorprendente _SwitchList no funcione porque devuelve una cadena , mientras que el operador IN requiere un valor de tabla ; Por cierto, IN es el azúcar de sintaxis para la función CONTAINSROW().

No se puede obtener ninguna información útil sobre el modelo de datos en sí; el único consejo que puedo ofrecer es usar una cortadora como esta,

 ... IN Values(OPT[Type])

ThxAlot_0-1710092445317.png

Gracias por su respuesta. Me gusta su solución, excepto que quiero una configuración predeterminada si no eligen nada. Conseguí que funcionara a mi manera, pero modificado de mi intento original.
Por cierto, pensé _SwitchList devolvería una lista, no una cadena. Claramente me equivoqué.
Gracias de nuevo.

Syndicate_Admin
Administrator
Administrator

Esto fue lo más limpio que pude hacer que el código siguiera funcionando como se esperaba.

justinh_0-1709934566952.png

Esta versión incluso mantiene los "KeepFilters" en su lugar:

VAR _ConversionType = [Selected Conversion Type]
VAR _Table = 
	CALCULATETABLE(
		SUMMARIZE(
			b_Assortment_Bridge,
			b_Assortment_Bridge[Inventory_Key],
			b_Assortment_Bridge[Assortment StdCost Ratio],
			b_Assortment_Bridge[Assortment Flag]
		),
		KEEPFILTERS( 
			SWITCH(
				_ConversionType,
				"Both",
					b_Assortment_Bridge[Assortment Flag] IN {"", "Assortment SKU", "Set - Component SKU"},
				"Assortments",
					b_Assortment_Bridge[Assortment Flag] IN {"", "Assortment SKU", "Set - Inventory SKU"},
				"Sets",
					b_Assortment_Bridge[Assortment Flag] IN {"", "Set - Component SKU"},
				"Off",
					b_Assortment_Bridge[Assortment Flag] IN {"", "Set - Inventory SKU"}
			)
		)
	)
VAR _Measure = 
	SUMX(
		_Table,
		CALCULATE( [.Sales - Selling SKUs] ) * [Assortment StdCost Ratio]
	)

RETURN
	_Measure

Helpful resources

Announcements
Microsoft Fabric Learn Together

Microsoft Fabric Learn Together

Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

Find out what's new and trending in the Fabric Community.