Check your eligibility for this 50% exam voucher offer and join us for free live learning sessions to get prepared for Exam DP-700.
Get StartedDon'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.
I have a few columns that have values like this:
[Value 1].[Value 2].[Value 3]
I need to create a new column (in DAX, preferably not Power Query due to DirectQuery limitations) that captures Value 3. Is there a way to do this? Value 1 is easy enough as I can use a mid formula to capture everything between [ and ], but Value 3 is a bit tricker. Note: Values 1, 2, and 3 can be any number of characters so I can't make any assumptions about the length of those strings of text.
I used something like this to capture value 1, FYI:
Solved! Go to Solution.
Hi @bc1985 ,
You can write to the calculated column:
value3 =
VAR _text = LEFT('Table'[Column1], FIND(".", 'Table'[Column1]))
VAR _len = LEN(_text)
VAR _len2 = LEN('Table'[Column1])
VAR _text2 = MID('Table'[Column1],_len+2,_len2 - _len)
VAR _text3 = LEFT(_text2, FIND(".", _text2))
VAR _len3 = LEN(_text3)
VAR _text4 = MID(_text2,_len3+2,_len2-_len3)
RETURN
LEFT(_text4,LEN(_text4)-1)
The final result is shown below:
If your Current Period does not refer to this, please clarify in a follow-up reply.
Best Regards,
Clara Gong
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
An update: it seems the reason "FIND" works for my formula but not yours is because you need to use the four argument version for DirectQuery as there is no equivalent two argument version in SQL. I made the adjustment and yours works for me!
For posterity, here is the full function that worked:
value3=
VAR _len3 = LEN(_text3)
VAR _text4 = MID(_text2,_len3+2,_len2-_len3)
RETURN
VAR _text = LEFT(Table1[Column], FIND(".", Table1[Column],1,0))
VAR _len = LEN(_text)
VAR _len2 = LEN(Table1[Column])
VAR _text2 = MID(Table1[Column],_len+2,_len2 - _len)
VAR _text3 = LEFT(_text2, FIND(".", _text2,1,0))
VAR _len3 = LEN(_text3)
VAR _text4 = MID(_text2,_len3+2,_len2-_len3)
RETURN
LEFT(_text4,LEN(_text4)-1)
Hi @bc1985 ,
You can write to the calculated column:
value3 =
VAR _text = LEFT('Table'[Column1], FIND(".", 'Table'[Column1]))
VAR _len = LEN(_text)
VAR _len2 = LEN('Table'[Column1])
VAR _text2 = MID('Table'[Column1],_len+2,_len2 - _len)
VAR _text3 = LEFT(_text2, FIND(".", _text2))
VAR _len3 = LEN(_text3)
VAR _text4 = MID(_text2,_len3+2,_len2-_len3)
RETURN
LEFT(_text4,LEN(_text4)-1)
The final result is shown below:
If your Current Period does not refer to this, please clarify in a follow-up reply.
Best Regards,
Clara Gong
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
An update: it seems the reason "FIND" works for my formula but not yours is because you need to use the four argument version for DirectQuery as there is no equivalent two argument version in SQL. I made the adjustment and yours works for me!
For posterity, here is the full function that worked:
value3=
VAR _len3 = LEN(_text3)
VAR _text4 = MID(_text2,_len3+2,_len2-_len3)
RETURN
VAR _text = LEFT(Table1[Column], FIND(".", Table1[Column],1,0))
VAR _len = LEN(_text)
VAR _len2 = LEN(Table1[Column])
VAR _text2 = MID(Table1[Column],_len+2,_len2 - _len)
VAR _text3 = LEFT(_text2, FIND(".", _text2,1,0))
VAR _len3 = LEN(_text3)
VAR _text4 = MID(_text2,_len3+2,_len2-_len3)
RETURN
LEFT(_text4,LEN(_text4)-1)
Inexplicably, I get an error saying "Function 'FIND' is not allowed as part of calculated column DAX expressions on DirectQuery models". Very strange since my DAX before did not throw that error. DirectQuery restrictions seem arbitrary and inconsistent.
Hi @bc1985
I am assuming delimiter will be always going to be '.'
PLease check following formule for calculated column
value3 = RIGHT('Table'[Column1], FIND(".", 'Table'[Column1] & ".")-1)
Thanks and Regards,
Sayali
Please mark the question solved when done and consider giving a thumbs up if posts are helpful!!
Proud to be a Super User!
Inexplicably, I get an error saying "Function 'FIND' is not allowed as part of calculated column DAX expressions on DirectQuery models". Very strange since my DAX before did not throw that error. DirectQuery restrictions seem arbitrary and inconsistent. Would there be a way to do this without find/search? Or is there any explanation for why 'find' works in my formula above but not here?
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Prices go up Feb. 11th.
Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.
User | Count |
---|---|
145 | |
85 | |
66 | |
52 | |
48 |
User | Count |
---|---|
215 | |
90 | |
83 | |
67 | |
59 |