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

Don't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.

Reply
jatanp
Regular Visitor

How to define measures automatically via custom connector

Hello,

 

We are planning to build a PowerBI custom connector for our product. The backend would be mostly responding with csv / json tabular data, however this data may require some special interpretation at PowerBI level. Basically we have - and ~ (no rollup) rollup operators which don't work in powerbi aggregation.

 

We have found the way to define a custom measure using ISINSCOPE function to perform this custom aggregation in matrix and other visualization (it's a standard technique used by many to determine the level of record and multiply the value with -1 / 1 while summing up).

 

Now the question is that we want to automatically define the necessary measures by our custom connector when the model is loaded in PowerBI. We dont want user to do this every time they load the model.

 

Is there any way in PowerQuery SDK to achieve this ? I hit upon C# scripts to define the measures but I am still exploring, and am really not clear how C# script would go inside custom connector.

 

Any help / direction is appreciated.

 

Thanks !

4 REPLIES 4
v-heq-msft
Community Support
Community Support

Hi @jatanp ,
Thanks for @TomMartens  reply.
Using a template application it is indeed possible to set up the measure in advance during the creation of the report. if you are not able to create a template application you can try to use m code to create custom columns to achieve a similar effect as the measure. Using m code allows you to create from the time you connect to the data source.

Add a custom column - Power Query | Microsoft Learn

Best regards,
Albert He

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly

Thanks @v-heq-msft for the custom column pointer.

 

I used the same DAX formula for the measure "Level" which I defined earlier to custom column "Level"

and PowerBI did accept the formula without any issues.

 

 

Level = VAR __list = { IF(ISINSCOPE(Query1[Level01]),1,-1),
IF(ISINSCOPE(Query1[Level02]),2,-1),
IF(ISINSCOPE(Query1[Level03]),3,-1),
IF(ISINSCOPE(Query1[Level04]),4,-1),
IF(ISINSCOPE(Query1[Level05]),5,-1),
IF(ISINSCOPE(Query1[Level06]),6,-1),
IF(ISINSCOPE(Query1[Level07]),7,-1),
IF(ISINSCOPE(Query1[Level08]),8,-1),
IF(ISINSCOPE(Query1[Level09]),9,-1),
IF(ISINSCOPE(Query1[Level10]),10,-1) }
RETURN 
MAXX( __list, [Value] )

 

 

However, it does not work the way the measure worked. It looks like ISINSCOPE function would work only when it is used as part of measure. In case of custom column column, it just keeps returning FALSE.

 

I tried building hierarchy out of the given levels in powerbi but no help.

 

Could you please guide and point me into right the direction.

jatanp
Regular Visitor

Thanks @TomMartens , templating would not be possible given the design and the possible usage. Please let me know if any other technique we could implement.

It feels pretty odd that PowerBI provides Model object via Tabular package to program in C# (ref: Automatically create measures in Power BI using VS Code - Phil Seamark on DAX) 

 

but not in the sdk.

TomMartens
Super User
Super User

Hey @jatanp ,

 

the Power Query SDK is not the place to define a measure. If you want to create a solution that you want to roll-out to your customers I recomment to create a Power BI Template file:

Depending on the way you want to spread your "product", you can also consider to create a template app:

Hopefully this provides some ideas of how to tackle your challenge.

 

Regards,

Tom

 



Did I answer your question? Mark my post as a solution, this will help others!

Proud to be a Super User!
I accept Kudos 😉
Hamburg, Germany

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!

Jan25PBI_Carousel

Power BI Monthly Update - January 2025

Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.

Jan NL Carousel

Fabric Community Update - January 2025

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