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

The Power BI DataViz World Championships are on! With four chances to enter, you could win a spot in the LIVE Grand Finale in Las Vegas. Show off your skills.

Reply
Jeremias_Mena08
New Member

Optmización de función DAX

Buenas noches foro,

A continuación comparto el código de un función DAX que me gustaría optimizar. La idea es que lograr conseguir el género que tiene mayor cantidad de streams. Leí que una posibilidad podría ser implementar una tabla virtual además de utilizar la función MAXX, pero no estoy seguro de ello. ¿Qué sugerencias tienen? Desde ya muchas gracias!

Código

Género más escuchado =
 VAR ALTERNATIVA_INDEPENDIENTE = [Streams ALTERNATIVA/INDEPENDIENTE]
 VAR BACHATA = [Streams BACHATA]
 VAR BLUES = [Streams BLUES]
 VAR COUNTRY = [Streams COUNTRY]
 VAR ELECTRONICA = [Streams ELECTRONICA]
 VAR HIP_HOP_RAP = [Streams HIP-HOP/RAP]
 VAR JAZZ = [Streams JAZZ]
 VAR POP = [Streams POP]
 VAR RB_SOUL = [Streams R&B/SOUL]
 VAR REGGAE = [Streams REGGAE]
 VAR REGIONAL = [Streams REGIONAL]
 VAR REGUETON = [Streams REGUETON]
 VAR ROCK = [Streams ROCK]
 VAR SAMBA = [Streams SAMBA]
 VAR URBANO = [Streams URBANO]
 VAR NO_DETERMINADO = [Streams NO DETERMINADO]
 RETURN
 SWITCH(
    TRUE(),
    ALTERNATIVA_INDEPENDIENTE > BACHATA && ALTERNATIVA_INDEPENDIENTE > BLUES && ALTERNATIVA_INDEPENDIENTE > COUNTRY &&
    ALTERNATIVA_INDEPENDIENTE > ELECTRONICA && ALTERNATIVA_INDEPENDIENTE > HIP_HOP_RAP && ALTERNATIVA_INDEPENDIENTE > JAZZ &&
    ALTERNATIVA_INDEPENDIENTE > POP && ALTERNATIVA_INDEPENDIENTE > RB_SOUL && ALTERNATIVA_INDEPENDIENTE > REGGAE &&
    ALTERNATIVA_INDEPENDIENTE > REGIONAL && ALTERNATIVA_INDEPENDIENTE > REGUETON && ALTERNATIVA_INDEPENDIENTE > ROCK &&
    ALTERNATIVA_INDEPENDIENTE > SAMBA && ALTERNATIVA_INDEPENDIENTE > URBANO &&
    ALTERNATIVA_INDEPENDIENTE > NO_DETERMINADO, "ALTERNATIVA/INDEPENDIENTE",
   
    BACHATA > ALTERNATIVA_INDEPENDIENTE && BACHATA > BLUES && BACHATA > COUNTRY && BACHATA > ELECTRONICA &&
    BACHATA > HIP_HOP_RAP && BACHATA > JAZZ && BACHATA > POP && BACHATA > RB_SOUL && BACHATA > REGGAE &&
    BACHATA > REGIONAL && BACHATA > REGUETON && BACHATA > ROCK && BACHATA > SAMBA && BACHATA > URBANO
    && BACHATA > NO_DETERMINADO, "BACHATA",
   
    BLUES > ALTERNATIVA_INDEPENDIENTE && BLUES > BACHATA && BLUES > COUNTRY && BLUES > ELECTRONICA &&
    BLUES > HIP_HOP_RAP && BLUES > JAZZ && BLUES > POP && BLUES > RB_SOUL && BLUES > REGGAE &&
    BLUES > REGIONAL && BLUES > REGUETON && BLUES > ROCK && BLUES > SAMBA && BLUES > URBANO
    && BLUES > NO_DETERMINADO, "BLUES",
   
    COUNTRY > ALTERNATIVA_INDEPENDIENTE && COUNTRY > BACHATA && COUNTRY > BLUES && COUNTRY > ELECTRONICA &&
    COUNTRY > HIP_HOP_RAP && COUNTRY > JAZZ && COUNTRY > POP && COUNTRY > RB_SOUL && COUNTRY > REGGAE &&
    COUNTRY > REGIONAL && COUNTRY > REGUETON && COUNTRY > ROCK && COUNTRY > SAMBA && COUNTRY > URBANO
    && COUNTRY > NO_DETERMINADO, "COUNTRY",
   
    ELECTRONICA > ALTERNATIVA_INDEPENDIENTE && ELECTRONICA > BACHATA && ELECTRONICA > BLUES && ELECTRONICA > COUNTRY &&
    ELECTRONICA > HIP_HOP_RAP && ELECTRONICA > JAZZ && ELECTRONICA > POP && ELECTRONICA > RB_SOUL && ELECTRONICA > REGGAE &&
    ELECTRONICA > REGIONAL && ELECTRONICA > REGUETON && ELECTRONICA > ROCK && ELECTRONICA > SAMBA && ELECTRONICA > URBANO
    && ELECTRONICA > NO_DETERMINADO, "ELECTRONICA",
   
    HIP_HOP_RAP > ALTERNATIVA_INDEPENDIENTE && HIP_HOP_RAP > BACHATA && HIP_HOP_RAP > BLUES && HIP_HOP_RAP > COUNTRY &&
    HIP_HOP_RAP > ELECTRONICA && HIP_HOP_RAP > JAZZ && HIP_HOP_RAP > POP && HIP_HOP_RAP > RB_SOUL && HIP_HOP_RAP > REGGAE &&
    HIP_HOP_RAP > REGIONAL && HIP_HOP_RAP > REGUETON && HIP_HOP_RAP > ROCK && HIP_HOP_RAP > SAMBA && HIP_HOP_RAP > URBANO
    && HIP_HOP_RAP > NO_DETERMINADO, "HIP-HOP/RAP",
   
    JAZZ > ALTERNATIVA_INDEPENDIENTE && JAZZ > BACHATA && JAZZ > BLUES && JAZZ > COUNTRY &&
    JAZZ > ELECTRONICA && JAZZ > HIP_HOP_RAP && JAZZ > POP && JAZZ > RB_SOUL && JAZZ > REGGAE &&
    JAZZ > REGIONAL && JAZZ > REGUETON && JAZZ > ROCK && JAZZ > SAMBA && JAZZ > URBANO
    && JAZZ > NO_DETERMINADO, "JAZZ",
   
    POP > ALTERNATIVA_INDEPENDIENTE && POP > BACHATA && POP > BLUES && POP > COUNTRY &&
    POP > ELECTRONICA && POP > HIP_HOP_RAP && POP > JAZZ && POP > RB_SOUL && POP > REGGAE &&
    POP > REGIONAL && POP > REGUETON && POP > ROCK && POP > SAMBA && POP > URBANO
    && POP > NO_DETERMINADO, "POP",
   
    RB_SOUL > ALTERNATIVA_INDEPENDIENTE && RB_SOUL > BACHATA && RB_SOUL > BLUES && RB_SOUL > COUNTRY &&
    RB_SOUL > ELECTRONICA && RB_SOUL > HIP_HOP_RAP && RB_SOUL > JAZZ && RB_SOUL > POP && RB_SOUL > REGGAE &&
    RB_SOUL > REGIONAL && RB_SOUL > REGUETON && RB_SOUL > ROCK && RB_SOUL > SAMBA && RB_SOUL > URBANO
    && RB_SOUL > NO_DETERMINADO, "R&B/SOUL",
   
    REGGAE > ALTERNATIVA_INDEPENDIENTE && REGGAE > BACHATA && REGGAE > BLUES && REGGAE > COUNTRY &&
    REGGAE > ELECTRONICA && REGGAE > HIP_HOP_RAP && REGGAE > JAZZ && REGGAE > POP && REGGAE > RB_SOUL &&
    REGGAE > REGIONAL && REGGAE > REGUETON && REGGAE > ROCK && REGGAE > SAMBA && REGGAE > URBANO
    && REGGAE > NO_DETERMINADO, "REGGAE",
   
    REGIONAL > ALTERNATIVA_INDEPENDIENTE && REGIONAL > BACHATA && REGIONAL > BLUES && REGIONAL > COUNTRY &&
    REGIONAL > ELECTRONICA && REGIONAL > HIP_HOP_RAP && REGIONAL > JAZZ && REGIONAL > POP && REGIONAL > RB_SOUL &&
    REGIONAL > REGGAE && REGIONAL > REGUETON && REGIONAL > ROCK && REGIONAL > SAMBA && REGIONAL > URBANO
    && REGIONAL > NO_DETERMINADO, "REGIONAL",
   
    REGUETON > ALTERNATIVA_INDEPENDIENTE && REGUETON > BACHATA && REGUETON > BLUES && REGUETON > COUNTRY &&
    REGUETON > ELECTRONICA && REGUETON > HIP_HOP_RAP && REGUETON > JAZZ && REGUETON > POP && REGUETON > RB_SOUL &&
    REGUETON > REGGAE && REGUETON > REGIONAL && REGUETON > ROCK && REGUETON > SAMBA && REGUETON > URBANO
    && REGUETON > NO_DETERMINADO, "REGUETON",
   
    ROCK > ALTERNATIVA_INDEPENDIENTE && ROCK > BACHATA && ROCK > BLUES && ROCK > COUNTRY &&
    ROCK > ELECTRONICA && ROCK > HIP_HOP_RAP && ROCK > JAZZ && ROCK > POP && ROCK > RB_SOUL &&
    ROCK > REGGAE && ROCK > REGIONAL && ROCK > REGUETON && ROCK > SAMBA && ROCK > URBANO
    && ROCK > NO_DETERMINADO, "ROCK",
   
    SAMBA > ALTERNATIVA_INDEPENDIENTE && SAMBA > BACHATA && SAMBA > BLUES && SAMBA > COUNTRY &&
    SAMBA > ELECTRONICA && SAMBA > HIP_HOP_RAP && SAMBA > JAZZ && SAMBA > POP && SAMBA > RB_SOUL &&
    SAMBA > REGGAE && SAMBA > REGIONAL && SAMBA > REGUETON && SAMBA > ROCK && SAMBA > URBANO
    && SAMBA > NO_DETERMINADO, "SAMBA",
   
    URBANO > ALTERNATIVA_INDEPENDIENTE && URBANO > BACHATA && URBANO > BLUES && URBANO > COUNTRY &&
    URBANO > ELECTRONICA && URBANO > HIP_HOP_RAP && URBANO > JAZZ && URBANO > POP && URBANO > RB_SOUL &&
    URBANO > REGGAE && URBANO > REGIONAL && URBANO > REGUETON && URBANO > ROCK && URBANO > SAMBA
    && URBANO > NO_DETERMINADO, "URBANO",
    "NO DETERMINADO"
 )

 

 

2 REPLIES 2
Syndicate_Admin
Administrator
Administrator

Hola @Jeremias_Mena08 ,

No estoy seguro de qué tipo de función tiene aquí, ¿qué calculan, sin embargo, asumo que cada uno de estos montantes se guarda en una columna en algún lugar, correcto?

Yo añadiría algo parecido a esto:

Most Stream =
_TempTable = ADDCOLUMNS(VALUES(Table[Music Category]), "Streams",[Streams])
Return

MAXX ( TOPN(1, temp_table, [Sales],DESC), Table[Music Category])

La sintaxis [Streams] debe ser una medida del modelo que cuente y/o sume el número de flujos.

En este caso se calculan la cantidad de streams que tiene un género en particular a través de una medida

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

FebPBI_Carousel

Power BI Monthly Update - February 2025

Check out the February 2025 Power BI update to learn about new features.

Feb2025 NL Carousel

Fabric Community Update - February 2025

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

Top Solution Authors
Top Kudoed Authors