Un usuario Pregunto ✅
Greg_Deckler
En mi reciente búsqueda para crear o catalogar tantos equivalentes de DAX para funciones de Excel, con DEC2BIN y BIN2DEC descubierto, podemos implementar una función AND bit a bit, BITAND:
BITAND =
VAR __Decimal1 = SELECTEDVALUE('Decimal1'[Decimal1],0)
VAR __Decimal2 = SELECTEDVALUE('Decimal2'[Decimal2],0)
RETURN
SWITCH(TRUE(),
__Decimal1 = 0 || __Decimal2 = 0,0,
VAR __Table1 =
ADDCOLUMNS(
GENERATESERIES(0,LOG(__Decimal1,2),1),
"Bit",MOD(TRUNC(__Decimal1 / POWER(2,[Value])),2)
)
VAR __Table2 =
ADDCOLUMNS(
GENERATESERIES(0,LOG(__Decimal2,2),1),
"Bit",MOD(TRUNC(__Decimal2 / POWER(2,[Value])),2)
)
VAR __Table =
ADDCOLUMNS(
ADDCOLUMNS(
GENERATESERIES(0,MAXX({ COUNTROWS(__Table1), COUNTROWS(__Table2) },[Value]) - 1),
"And",IF(
AND(
MAXX(FILTER(__Table1,[Value] = EARLIER([Value])),[Bit]),
MAXX(FILTER(__Table2,[Value] = EARLIER([Value])),[Bit])
),1,0
)
),
"Decimal",POWER(2,[Value]) * [And]
)
RETURN
SUMX(__Table,[Decimal])
)
NOTA: No admite números negativos, pero tampoco la función BITAND de Excel.
eyJrIjoiYWQxNjljYmItZThkNy00MTc4LWIzZTctMjY4ZWE0Zjc4OTJiIiwidCI6IjRhMDQyNzQzLTM3M2EtNDNkMi04MjdiLTAwM2Y0lYiZiLTAwM2Y0lY